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Дорогой читатель, ты держишь в руках юбилейный — двадцать 
пятый — номер нашего журнала. С чем тебя, а также себя мы 
и поздравляем. Когда мы начинали, а было это два с небольшим года 
назад, все было не так: и время было не то, и законы, и компьютеры 
были не те, да и страна была не та. Еще не было ни малых 
предприятий, ни цветных лазерных принтеров, ни бирж, 
ни ноутбуков, ни ГКЧП. Зато были КПСС, КГБ и хлеб по 20 копеек. 

И даже время от времени колбаса. Что лучше — ощущать себя 
относительно сытым или относительно свободным — каждый 
решает сам. Впрочем, в нашей чудной стране каждое принятое 
решение в итоге оказывается неверным... 

Когда мы взялись за издание этого журнала, то, как выяснилось, 
даже отдаленно не представляли тех трудностей, с которыми 
столкнемся, но, как бы то ни было, журнал выходит более-менее 
регулярно (хотя такой регулярности не пожелаем своим 
читателям), бумажно-полиграфические проблемы относительно 
решены (не спорим, бывает и лучше), и главное для нас сегодня — 
найти решение вечного вопроса: как угодить максимальному числу 
читателей. Это всегда являлось нашей целью. Ведъ чем мы 
отличаемся от других компьютерных журналов, выходящих в нашей 
стране? В них в основном заложена одна схема: перевод статей 
из весьма уважаемых западных журналов. Но что годится для 
западного читателя, зачастую не подходит нашему. Конечно, 
интересен совет, что для решения такой-то проблемы достаточно 
заменить 386/20 на 486/50, но у нас, пожалуй, многих больше 
интересует, что можно выжать из старенькой ХТ 'ишки. Поэтому 
мы стараемся, начав и продолжая линию как можно более 
объективных обзоров событий компьютерного мира и сообщая 
о всех достойных внимания новостях, давать информацию, 
ориентированную исключительно на конкретные нужды нашего 
небогатого, но крайне любознательного и смекалистого читателя. 
Всем угодить невозможно, это понятно: начинающим надо одно, 
просто пользователям другое, крутым программистам — третье, 
электронщикам — четвертое и т.д. Статья, с упоением 
прочитанная одним, вызовет скуку у другого — это неизбежно, 
как невозможно совершенство. В книге Лоуренса Питера “Принцип 
Питера“ приведен отрывок из армейских инструкций: “Колышки 



для палаток... должны быть окрашены в оранжевый цвет. Яркая 
окраска — лучшее средство, чтобы быстро отыскать колышки... 

При пользовании колышками, окрашенными в яркий оранжевый цвет, 
их следут вбивать в землю глубоко, так чтобы они не были видны и . 
Конечно, можно согласиться со словами Грушо Маркса, что 
" военная мудрость есть понятие, содержащее противоречие в самом 
себе", но в данном случае все верно: либо колышки видны 
неприятелю, либо они не видны никому. Сегодня мы видим решение 
этой проблемы в ориентировании на письма читателей, на принцип 
" о чем просят, о том споем". Так что пишите письма и, не 
стесняясь, рисуйте вопросы, как поет Булат Шалвович: "Ничего, 
что мы чужие. Вы рисуйте! Я потом, что не понятно, объясню". 
Более того, написавшие самые толковые письма, возможно, получат 
некоторое удовлетворение в виде пачки дензнаков — в этом номере 
мы сообщаем о новом конкурсе на лучшую публикацию года, правда, 
итоги прошлогоднего конкурса удастся подвести, видимо, не ранее 
третьего номера. 

Дорогой читатель! Позволь с некоторым опозданием поздравить 
тебя с Новым годом и пожелать тебе в первую очередь бодрости 
и оптимизма. Без оптимизма в наше нелегкое время просто 
не прожитъ, а бодрость нужна, чтобы справляться с отдельными 
временными трудностями. Ну, и конечно — удачи! А мы сделаем 
все, чтобы помочь тебе хоть в чем-то — хотя бы в решении 
компьютерных проблем. 


Б. Мол чанов, главный редактор 
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ИНТЕРФЕЙСЫ 
ПЕРИФЕРИЙНЫХ 

УСТРОЙСТВ — 
ПОСЛЕДОВ А ТЕЛЬНЫЙ 
И ПАРАЛЛЕЛЬНЫЙ 


Подсоединение периферийных 
устройств, таких как мышка или 
принтер, к персональному ком- 
пьютеру производится через так 
называемые устройства сопряже- 
ния (адаптеры). Обычно адаптеры 
выполнены в виде отдельных плат 
ввода-вывода (Іприі-Оиіриі Сагб, 
І/О Сагсі), вставляемых в разъемы 
расширения на системной плате. 

Вообще говоря, взаимодействие 
периферийного устройства с адап- 
тером происходит с одним 
(возможно одним из двух) стан- 
дартным интерфейсом, определя- 
ющим, в частности, тип и “род“ 
соединителя, уровни и длительно- 
сти электрических сигналов, про- 
токолы обмена. К одной плате 
ввода-вывода может подключаться 
несколько устройств, если, ко- 
нечно, на ней конструктивно раз- 
мещено несколько адаптеров 
устройств, которые в случае пер- 
сональных компьютеров часто на- 
зывают портами ввода-вывода. 


Порты бывают последовательные, 
т.е. информационные биты пере- 
даются последовательно один за 
другим, и параллельные, когда не- 
сколько бит данных передаются 
одновременно. Для подключения 
джойстика служит специальный 
аналоговый игровой адаптер — 
Сате Абаріег. Обычно он . распо- 
лагается на плате ввода-вывода 
вместе с параллельным и последо- 
вательными портами. Плату со 
всеми этими портами называют, 
как правило, многофункциональ- 
ной платой ввода-вывода (МиНі 
І/О Сагсі). Параллельные порты 
используются обычно для подклю- 
чения принтера (в ряде случаев 
плоттера или сканера). Интерфейс 
параллельного порта выполнен в 
соответствии с интерфейсом Сеп- 
ігопісз (получившим свое название 
по имени американской фирмы — 
производителя принтеров, предло- 
жившей в свое время собственный 
интерфейс для принтера). Сегодня 


практически все принтеры, пред- 
назначенные для персоналок, ис- 
пользуют интерфейс Сепігопісз, 
так что при подключении принте- 
ра к компьютеру проблем не воз- 
никает. 


СЕИТКОИІС5: 

байт за байтом 

Интерфейс Сепігопісз исполь- 
зует электрические сигналы ТТБ- 
уровня (+5 В и О В) и еще не так 
давно был чаще всего конструк- 
тивно выполнен на нескольких 
ТТЬ-микросхемах. Эти микро- 
схемы служат для декодирования 
адреса, промежуточного хранения 
и инвертирования отдельных сиг- 
налов (рис. 1). В последнее время 
широкое распространение полу- 
чили параллельные адаптеры, в 
которых практически все функции 
отдельных ТТЪ-микросхем объе- 
динены в одной БИС 82С11, вы- 
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ИНТЕРФЕЙСЫ ПЕРИФЕРИЙНЫХ УСТРОЙСТВ — ПОСЛЕДОВАТЕЛЬНЫЙ И ПАРАЛЛЕЛЬНЫЙ 



РИС . 1 . 


течение приблизи- 
тельно 10 мкс удер- 
живает эту линию в 
активном состоянии. 

***Визу*** Если прин- 
тер не может принять 
данные, то сигнал ак- 
тивизируется. Это мо- 
жет произойти, на- 
пример, в следующих 
случаях: при инициа- 
лизации принтера, ес- 
ли принтер находится 
в состоянии оГМіпе, 
при появлении ошиб- 
ки, а также при обна- 
ружении конца бума- 
ги. 


полненной по КМОП-технологии 
(уровни сигналов по-прежнему 
ТТЪ). Обычно эта микросхема 
расположена на плате в специаль- 
ной панельке — сНір зоскеі — и 
не зря. Электрические наводки в 
кабеле (не говоря уже о разных 
“землях 44 принтера и компьютера) 
достаточно часто выводят эту мик- 
росхему из строя (КМОП — кап- 
ризная вещь!). В таких случаях 
можно лишь пожалеть о “старой 
доброй 44 ТТЬ-технике. 

Для того чтобы избежать оши- 
бок и потери информации при пе- 
редаче данных с ТТЬ-уровнями, 
максимальная длина кабеля для 
принтера не должна быть больше 
двух-трех метров. Обычно для 
сигналов данных и управления в 
кабеле используются витые пары, 
а все проводники заключены в 
общий экран. С. помощью специ- 
альных дополнительных устройств 
(усилителей сигналов) длина ка- 
беля может быть без особых про- 
блем увеличена до десяти, а то и 
до двадцати метров. Основной за- 
дачей усилителей при этом явля- 
ется сохранение временных соот- 
ношений сигналов, их уровней и 
фронтов. Подсоединение кабеля к 
адаптеру (для пользователя — к 
компьютеру) производится через 
25-контактный разъем типа 
О — зМеІІ, распределение сигналов 
по контактам которого приведено 
на рис. 2. Со стороны принтера 
используется специальный 36-кон- 
тактный разъем типа Сепігопісз; 


распределение сигналов по кон- 
тактам показано на рис.З. Надо 
сказать, что для простой передачи 
данных требуются не все сигналы, 
определенные стандартом Сеп- 
Ігопісз. Для того чтобы обеспечить 
функционирование интерфейса, 
достаточно использовать только 
8 бит данных Ш0 — 07), строб- 
сигнал данных Шаіа 8ігоЬе) и 
сигнал занятости принтера (Визу). 
Пара слов о сигналах интерфейса 
Сепігопісз, используемых для ра- 
боты с принтерами. 

***Оаіа ЗігоЬе*** Когда компью- 
тер посылает данные на прин- 
тер, он в течение 5 мкс должен 
активировать этот сигнал. Этим 
принтеру сообщается о том, что 
данные на соответствующих ши- 
нах готовы. 

***ОаІа*** По этим 
8 сигнальным ли- 
ниям данные пере- 
даются от компью- 
тера к принтеру. 

После установле- 
ния сигнала Оаіа 
ЗігоЬе принтер чи- 
тает эту информа- 
цию. 

* * * Аск п одѵі егі^е* * * 

Если принтер при- 
нял выставленные 
компьютером дан- 
ные, то в подт-вер- 
ждение он в 


***Рарег оиі*** Этот сигнал сооб- 
щает компьютеру о том, что за- 
кончилась бумага. Если вставить 
в принтер новый лист, сигнал 
дезактивируется. 

***8е1ес1*** С помощью этого сиг- 
нала принтер сообщает машине, 
что он выбран и активен. У мно- 
гих принтеров данный сигнал 
имеет постоянное значение. 

***АиІо Іеесі*** Активирование 
этого сигнала вызывает продви- 
жение бумаги в принтере на од- 
ну строку вперед. Как правило, 
переход на другую строку осу- 
ществляется программно — вы- 
водом в порт определенных сим- 
волов. 


Контакт 

Направление 

Сигнал 

1 

Выход 

йаТа ЗТгоЬе 

2 

Выход 

ОаТа 0 

3 

Выход 

ОаХа 1 

4 

Выход 

ЭаТа 2 

5 

Выход 

ОаТа 3 

6 

Выход 

йаТа 4 

7 

Выход 

ОаТа 5 

8 

Выход 

ОаХа 6 

9 

Выход 

ОаХа 7 

10 

Вход 

Аскпоѵѵіесіде 

11 

Вход 

Визу 

12 

Вход 

Рарег ОиТ 

13 

Вход 

Зеіест 

14 

Выход 

АиТо 1"еес1 

15 

Вход 

Ег гог 

16 

Выход 

ІпіТ 

17 

Выход 

Зеіест ІприТ 

18-25 

— 

Сгоипсі 


Рис . 2 . 
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***Еггог*** Этот 
сигнал от 

принтера мо- 
жет быть ак- 
тивным в сле- 
дующих ситуа- 
циях: если 

принтер нахо- 
дится в состоя- 
нии оГМіпе, ес- 
ли закончилась 
бумага или во 
время печати 
произошла 
ошибка. 


Шина 

адреса 


Декодер - 
Адреса — 

Шина данных 

Прерывание 


Выбор микросхемы 


Выбор регистров 




1.8432 МГц 



Приемники ЕІА 


Соединитель 
типа й-зЬеІ I 


Контроллер 

Асинхронного 

Интерфейса 


Передатчики ЕІА <- 


***ІпіІ*** Если 
сигнал на этой 
линии будет 
активным в те- 
чение прибли- 
зительно 50- 

100 мкс, то происходит инициа- 
лизация принтера — как при его 
включении. 

***5е1есІ Іприі*** Активирование 
и дезактивирование этого сигна- 
ла аналогично подаче управляю- 
щих кодов ЭС1 Шеѵісе Сопігоі 
1 ) — выбор устройства и ЭС2 — 
отмена выбора устройства. 


Внешнее подключение 


***Сгоипс1*** Это сигнал 
“Корпус 44 (“Земля 44 ) для сигна- 
лов данных и управляющих сиг- 
налов. 

Персональный компьютер рабо- 
тает максимум с тремя параллель- 
ными портами, которые в М5-Э05 
имеют логические имена ІрП, 1рі2 
и ІріЗ. В адресном пространстве 
компьютера резервируются базо- 
вые адреса этих портов: ЗВСЬ, 
378Н и 278Н. Первый адрес 
обычно использу- 


вается перестановкой перемычек 
(Дитрегз) на плате, описание 
которых обычно приведено в 
технической документации на 
плату. 

Начиная с базового адреса, 
каждый адаптер принтера имеет в 
адресном пространстве три адреса. 
При этом первый адрес соответ- 
ствует регистру данных, посыла- 
емых от компьютера к принтеру. 
В случае использования ТТЬ-мик- 
росхем этот регистр часто бывает 


Контакт 

Направление 

Сигнал 

1 

Выход 

йаТа ЗТгоЬе 

2 

Выход 

ОаТа 0 

3 

Выход 

ОаТа 1 

4 

Выход 

йаТа 2 

5 

Выход 

ОаТа 3 

- 6 

Выход 

ЭаТа 4 

7 

Выход 

ЭаТа 5 

8 

Выход 

йаТа 6 

9 

Выход 

Оага 7 

10 

Вход 

Аскпоѵу/Іебде 

11 

Вход 

Визу 

12 

Вход 

Рарег ОиТ 

13 

Вход 

Зеіесі 

14 

Выход 

АиТо Геей 

15 

- 

N 0 соппест 

16 

- 

Спсі 

17 

- 

ЗНаззіз Опсі 

18 

Выход 

+5 V 

19-30 

- 

Спб 

31 

Вход 

ІП ІТ 

32 

Выход 

Еггог 

33 

_ 

Опб 

34 

- 

Сіоск 

35 

Выход 

ТезТ 

36 

Выход 

Зеіест ІприТ 


ется, если прин- реализован на микросхеме 

тер-порт нахо- 74Е5374. Чтение установленных 

дится, например, битов данных можно осуществить 

на плате графи- по тому же адресу. Физически 

ческого адаптера чтение данных происходит через 

Негсиіез или буфер данных, выполненный, на- 

ЕСА. На плате пример, на микросхеме 74П5244. 

МиИі І/О Сагсі Следующий адрес (базовый адрес 

адрес ІрП — плюс единица) позволяет читать 
378Н, а 1рі2 — регистр статуса адаптера 

278Н. Для прин- (расположенный, конечно, в 

терного порта принтере) через буферную мик- 

ІрП предусмот- росхему — часто 74П5240 (или 

рено аппаратное 741.5367 — 74Ь5368). В регистре 

прерывание статуса биты 3-7 позволяют опре- 

ІК(27, а для делить состояние некоторых сиг- 

1рі2 — ІК(}5, хо- налов интерфейса Сепігопісз: 

тя на практике бит 3 = 0: Еггог 

они используются бит 4=1: Зеіесі 

очень редко. Ус- бит 5 = 1: Рарег оиі 

тановка базовых бит 6 = 0: Аскпо^іесі^е 

адресов портов и бит 7 = 0: Визу 

возможность ис- Чтение регистра статуса имеет 


пользования пре- смысл при передаче данных на 
рываний настраи- принтер, для определения состо- 
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Обозначение 

Адреса 

Прерывание 

С0М1 

ЗР8И-ЗРРІ1 

ІР04 

С0М2 

2Р8Н-2РРН 

ІПОЗ 

СОМЗ 

ЗЕ8И-ЗЕРИ 

ІР010 (ІР02) 

С0М4 

2Е8Н-2ЕРИ 

ІР011 (ІР05) 


Рис . 5 . 


яния принтера и процесса пере- 
дачи данных. 

Адрес третьего порта (базовый 
адрес плюс 2) соответствует реги- 
стру управления интерфейса. Этот 
регистр (геаб опіу — только для 
чтения), для которого может 
использоваться микросхема 

74Б8174, позволяет определить 
следующие состояния принтера: 

бит 0 = 0: сигнал Эаіа БігоЪе 
активен, 

бит 1 =0: сигнал Аиіо Іееб 

включен, 

бит 2 = 0: инициализация 

принтера, 

бит 3=1: принтер выбран, 

бит 4 = 1: прерывание разре- 
шено. 

Для того чтобы работать с 
принтером из собственных про- 
грамм, проще всего использовать 
специальное прерывание ВІО$ іпі 
17Н. Однако, в некоторых случаях 
может потребоваться программи- 
рование на уровне регистров, 
тогда информация о приведенных 
выше регистрах просто необхо- 
дима. 

Интерфейс в мир К5-232 

Последовательный интерфейс 
может использоваться для боль- 
шинства периферийных устройств: 
плоттер, удаленный принтер, 
мышь, модем, программатор ПЗУ 
и т.д. До настоящего времени для 
последовательной связи использу- 
ются адаптеры с интерфейсом 
КЗ-232. Описание этого ин- 
терфейса было опубликовано 
Американской промышленной ас- 
социацией еще в 1969 году. Евро- 
пейским аналогом КЗ-232 явля- 
ются два стандарта, разработан- 


ные ССІТТ 
(Междуна- 
родный 
консульта- 
тивный ко- 
митет по 
телегра- 
фии и те- 
лефо- 
нии), — 
Ѵ.24 (ме- 
ханические 
характеристики) и Ѵ28 (эле- 
ктрические характеристики). Хотя 
первоначально КЗ-232 был пред- 
назначен для связи центральной 
машины с терминалами, его 
простота и богатые возможности 
обеспечили ему более широкое 
применение. В современной персо- 
налке может быть до четырех пос- 
ледовательных адаптеров, имею- 
щих логические имена соответст- 
венно СОМ1, СОМ2, СОМЗ и 
СОМ4. Структурная схема одного 
из адаптеров приведена на рис. 4. 
Базовые адреса адаптеров и соот- 
ветствующие прерывания приведе- 
ны на рис.5. Следует обратить 
внимание на тот факт, что ис- 
пользование прерываний ІК(}10 и 
ІК(211 в ІВМ РС/АТ возможно 
только на дополнительном (корот- 
ком) слоте. Таким образом, при- 
менение трех или четырех после- 
довательных портов с соответству- 
ющими прерываниями возможно 
только на плате ввода-вывода для 
РС/АТ (16 бит данных). В проти- 
вном случае можно задействовать 
только два прерывания (ІК(}4 и 
ІК(}3) или использовать, если воз- 
можно, прерывание ІК(}2 или 
ік<}5. 

В адресном пространстве портов 
РС 

последова- 
тельный 
адаптер 
занимает 
восемь 
последо- 
ватель- 
ных адре- 
сов, 

включая 
базовый. 

Однако с 
помощью 


определенного “трюка“ через эти 
восемь адресов происходит 
обращение к 11 регистрам, 
которые программируются соот- 
ветствующим образом. На рис. 6 
приведено полное обозначение 
этих регистров, описание же их по 
отдельным битам выходит за 
рамки данной статьи (по этому 
поводу существует большое коли- 
чество справочной литературы). 
По существу, сердцем последова- 
тельного адаптера является мик- 
росхема ИАКТ Шпіѵегзаі Азуп- 
сНгопоиз Кесеіѵег/Тгапзтіііег) — 
универсальный асинхронный при- 
емопередатчик 8250 или 16450. 
Декодирование адресов для этой 
микросхемы происходит либо на 
дискретных ТТБ-микросхемах, 
либо при помощи микросхемы 
программируемой логической мат- 
рицы (Рго^гашшаЫе Аггау Ьо^іс). 
Поскольку стандарт передачи и 
приема использует высокие уровни 
сигналов +/-15 В или +/-12 В, то 
для преобразования логических 
уровней в интерфейсные и наобо- 
рот используются микросхемы 
приемников и передатчиков, 
обычно 1489 и 1488. Каждая из 
этих микросхем включает в себя 
четыре приемника или четыре пе- 
редатчика. При передаче микрос- 
хема ІІАКТ преобразует парал- 
лельный код в последовательный и 
передает его побитно в линию, 
обрамляя исходную последова- 
тельность битами старта, останова 
и контроля. При приеме данных 
ПАКТ преобразует последователь- 
ный код в параллельный 
(разумеется, опуская служебные 
символы). Непременным условием 
правильной передачи/приема яв- 


Адрес 

Обозначение 

0 

ТНР ТгапзтіЮег Ноісііпд РедізТег 

0 

РВР Ресеіѵег ВиРРег РедізРег 

0 

0І_І_ Оіѵізог І_аТсМ 1-$В 

1 

01_М Оіѵізог 1_аРсЬ МЗВ 

1 

ІЕР ІпРеггирР ЕпаЫе РедізРег 

2 

1 1 Р ІпТеггирі: ІбепРіРісаРіоп РедізРег 

3 

ЮР ІЛпе СопРгоІ РедізТег 

4 

МСР Мобет СопРгоІ РедізРег 

5 

І.ЗР 1-іпе ЗТаТиз РедізРег 

6 

МЗР Мобет ЗТаТиз РедізРег 


Рис . 6 . 


КомпьютерПресс Г92 







АППАРАТНОЕ ОБЕСПЕЧЕНИЕ 


9 


Обозначение 

сигнала 

Контакты 

йВ9 

Контакты 

ЭВ25 

РОЭ 

1 

8 

РхЭ 

2 

2 

Тхй 

3 

3 

ЭТИ 

4 

20 

ОМ 

5 

7 

ЭЗР 

6 

6 

РТЗ 

7 

4 

стз 

8 

5 

РІ 

9 

22 


Рис . 7 . 


ляется одинаковая скорость работы 
приемного и передающего ІІАЯТ. 
Основным преимуществом после- 
довательной передачи является 
возможность пересылки данных на 
большие расстояния — как пра- 
вило, не менее 30 метров. Нема- 
ловажно и то, что в простейшем 
случае для приема и передачи не- 
обходимы только три сигнала: 
ТхО (ТгапзтИ Ваіа — Передача 
данных), КхИ (Кесеіѵе Оаіа — 
Прием данных) и СЫО 
(Сгоипё — Земля). 

В персональных компьютерах 
из 25 сигналов, предусмотренных 
стандартом К5-232, используются 
в соответствии с ЕІА только 9: три 
описанных выше и шесть, объеди- 
ненных общим названием Напё- 
зНаке-сигналы. При использовании 
этого интерфейса одно из 
устройств выступает как ОТЕ 
Фаіа Тегтіпаі Ециіртепі — Око- 
нечное устройство), а другое как 
ПСЕ Шаіа Сошшипісаііоп Ечиір- 
шепі — Устройство передачи дан- 
ных). Хотя, вообще говоря, разли- 
чие между ними состоит только в 
направлении используемых сигна- 
лов. Так, если сигнал для ЭТЕ яв- 
ляется входным, то для ОСЕ этот 
же сигнал будет выходным и на- 
оборот. На рис. 7 приведено рас- 
пределение по контактам девяти 
используемых сигналов для 
25-контактного и 9-контактного 
разъемов. Кстати, 9-контактный 
разъем для последовательного 
адаптера используется только на 


РС/АТ. При обмене 
данными могут исполь- 
зоваться различные про- 
токолы — правила об- 
мена — от простейшего, 
упомянутого выше и ра- 
ботающего только с тре- 
мя сигналами интер- 
фейса, до более слож- 
ных, использующих, на- 
пример, пару квитирую- 
щих (НапёзНаке) сигна- 
лов КТ5-СТ8. Различ- 
ные программы могут 
применять различные протоколы 
обмена, поэтому во избежание не- 
доразумений лучше всегда предва- 
рительно изучить со- 

ответствующие технические опи- 
сания. 

Скорость последовательной пе- 
редачи данных оценивается в бо- 
дах (бит полезной информации в 
секунду). Микросхемы II АКТ 8250 
рассчитаны на максимальную ско- 
рость 38400 бод, а 16450 — на 
115200 бод. Обычно передача дан- 
ных осуществляется на нескольких 
дискретных скоростях: 50, 75, ПО, 
150, 300, 600, 1200, 2400, 4800, 
9600 и 19200 бод. Для ІВМ РС 
максимальная скорость обмена 
обычно составляет 9600, а для 
Р8/2 — 19200 бод. При специ- 
альном программировании реги- 
стров можно достигнуть скорости 
обмена в 1 15200 бод. Различные 
коммерческие программы (типа 
ЕарПпк) используют эту возмож- 
ность. Конечно, чем выше ско- 


рость обмена, тем выше требова- 
ния к используемому кабелю, 
чтобы избежать ошибок при при- 
еме или передаче. Средства ВІ05 
(например, коммуникационное 
прерывание іпі 14Н) поддержива- 
ют скорости только до 9600 бод 
включительно. Это следует иметь 
в виду при написании собствен- 
ных программ обмена. Тактовая 
частота, используемая для ІІАКТ, 
обычно составляет 18432 кГц и 
стабилизирована благодаря ис- 
пользованию кварцевого генерато- 
ра. Из этой частоты формируются 
уже все упомянутые частоты. По- 
следовательный порт работает 
асинхронно — данные передаются 
без тактового сигнала. В этом слу- 
чае незначительное различие ско- 
ростей приема и передачи не вли- 
яет на качество обмена. На обеих 
сторонах должны быть установ- 
лены программно (или с помощью 
переключателей) следующие па- 
раметры: скорость передачи дан- 
ных, количество битов обмена (от 
5 до 8), количество стоповых би- 
тов (1 или 2), бит контроля (по 
четности или нечетности, при 
8 битах отсутствует). Передача 
данных начинается с изменения 
уровня напряжения на линии с 
-12 В до уровня +12 В (так 
называемый стартовый бит). 
Стоповые биты передаются 
уровнем напряжения -12 В. При 
использовании контроля по 
четности, соответствующий бит 
выбирается таким образом, что 
сумма битов данных и бита 
контроля представляет собой 
четное число. Аналогично вы- 
полняется контроль по нечетности. 

В заключение, пожалуй, нужно 


Номер 

контакта 

Направление 

сигнала 

Название 

сигнала 

1 

Выход 

+ 5 В 

2 

Вход 

Клавиша 1 джойстик А 

3 

Вход 

Значение X джойстик А 

4 

- 

Земля 

5 

- 

Земля 

6 

Вход 

Значение У джойстик А 

7 

Вход 

Клавиша 2 джойстик А 

8 

Выход 

+ 5 В 

9 

Выход 

+ 5 В 

10 

Вход 

Клавиша 1 джойстик В 

11 

Вход 

Значение X джойстик В 

12 

- 

Земля 

13 

Вход 

Значение У джойстик В 

14 

Вход 

Клавиша 2 джойстик В 

15 

Выход 

+ 5 В 


Рис . 8 . 
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сказать несколько слов об адап- 
тере джойстика, который, как 
правило, также расположен на 
МиНі І/О Сагсі. Распределение 
сигналов по контактам разъема 
для игрового адаптера приведено 
на рис. 8. Одной из особенностей 
этого разъема является то, что к 
нему, в отличие, например, от 
разъемов последовательного или 
параллельного адаптера, могут 
подключаться два джойстика 


одновременно. Такое соединение 
выполняется обычно посредством 
так называемого Ѵ-кабеля (два 
входа, один выход). Для тех, кто 
увлекается компьютерными иг- 
рами, нет нужды объяснять необ- 
ходимость именно двух джойсти- 
ков. Хотя, по правде говоря, на 
современном компьютере джой- 
стик выглядит анахронизмом. 

В адресном пространстве для 
Саше-адаптера зарезервировано 


поле адресов от 200Н до 207Н. На 
самом деле для этого адаптера до- 
статочно только одного адреса. 
Для РС/ХТ это, как правило, 
200Н, а для РС/АТ — 201 Н. Этим 
различием можно объяснить то, 
что иногда текстовые или игровые 
программы не распознают игровой 
адаптер. 

А.Борзенко 


Китай и Иран 
создают новые 
волоконные линии 

В то время, как в Россию 
и другие республики быв- 
шего Советского Союза ввоз 
оптико-волоконных кабелей 
по-прежнему запрещен За- 
падом, потому что разговоры 
по ним нельзя перехватить, 
у Китая и Ирана такой про- 
блемы нет. Китай создает 
волоконную линию длиной 
2.500 км, соединяющую 
Шанхай с Гуанчжоу. Иран 
закупил оптико-волоконную 
систему у шведской фирмы 
Егісззоп для северо-запад- 
ного района Ирана вблизи от 
иракской границы. Вскоре 
Егіс$$оп откроет отделение в 
Тегеране для дальнейшего 
развития бизнеса. Эти ново- 
сти появились как раз тогда, 
когда пресса сообщила, что 
Китай, возможно, помогал 
Ирану в его проекте созда- 
ния атомной бомбы. 

ТНе Теіериііпк Ноіііпе, 
НоѵетЬег 12 , 1991 

Улучшения в передаче 
сообщений между 
системами не за горами 

Стандарт Х.400 для пере- 
дачи сообщений между 
системами нуждается в еди- 
ной адресации, и предпри- 
нимаются шаги по ее созда- 
нию. В прошлом, однако, 
компании действовали сами 
по себе, и для создания 
общего стандарта потребу- 
ются переговоры. 


ВгШзН Теіесот соединит 
между собой свои системы в 
Соединенном Королевстве, 
США и Франции таким 
образом, что пользователи в 
этих стран будут пользо- 
ваться единой схемой адре- 
сации и электронной почтой 
к январю 1992 года. Пере- 
дача сообщений между 
этими службами еще потре- 
бует использования Х.400 
Мезза^е ЗѵгіісЫпя Зегѵісе, 
которая работает на сети ВТ 
Тутпеі. Но существует и но- 
вое автоматическое про- 
граммное обеспечение. 

Американская РасіГіс Веіі 
добавила схему адресации 
Х.400 к своей службе пере- 
дачи сообщений, чтобы все 
пользователи могли вместе 
создать базу данных удален- 
ных адресов, которой можно 
пользоваться при создании 
списков рассылки. ІпГогта- 
Ііои №і\ѵогк фирмы ІВМ 
представила ЕтаіІСоппесІ Гог 
Тгасііпя РаПпегз — службу, 
клиенты которой могут со- 
здать свои собственные си- 
стемы адресации или полу- 
чить помощь ІВМ при пре- 
образовании адресов по- 
ставщиков и покупателей. 

Наконец, и это может 
оказаться самым важным, 
Кеііх внесет свой вклад, на- 
чав перенос и обновление 
адресов сетей стандарта 
Х.400 с помощью Бігесіогу 
ЕхсЬапде ФХ). ИХ мог бы 
стать сердцем “Х.500“ — 
нового стандарта адресации. 
Программное обеспечение 
Кеііх подходит к системам 
Х.400 самых различных ти- 
пов компьютеров. 

ТНе Теіериііпз Ноіііпе , 
А ІоѵетЬег 12, 1991 


Электронное оформление 

счетов развивается: 

под двумя стандартами 

Электронная обработка 
счетов по стандартам ЕШ 
набирает популярность в 
мире, но испозуются два 
разных стандарта. Европа 
поддерживает ЕсІіГасі, а аме- 
риканские фирмы стоят за 
Х.12. 

ВгШзН Теіесот (ВТ) рас- 
кидывает свою службу ЕОІ- 
N61 по Великобритании и 
Европе. В 1985 году пакет- 
ная сеть Тутпеі начала ра- 
боту своей службы ЕОІ. Те- 
перь, когда владельцем сети 
является ВТ, две системы 
будут объединены. ВТ также 
предлагает жесткую связь с 
британскими компаниями и 
большим числом европей- 
ских узлов. Плата за под- 
писку отсутствует. 

В Москве группа развития 
системы ЕШГасІ под назва- 
нием РЕРІ сообщила кор- 
респонденту №ѵѵзЪуіез Ки- 
риллу Чащину, что желез- 
ные дороги и пароходства 
переходят от бумажек к 
электронной обработке сче- 
тов. Чтобы ускорить этот 
процесс, РЕРІ обеспечит до- 
ступ к базе данных по до- 
кументам по ЕсІіГасІ в Же- 
неве и будет продавать 
программное обеспечение 
французской фирмы Тгапз- 
рак. 

В США ЕЭІ-служба 
фирмы Зргіпі начнет пере- 
сылку счетов на факсимиль- 
ные аппараты, в электрон- 
ные почтовые ящики, си- 
стемы ВВЗ и по почте, в со- 
ответствии с Х.12. Это дела- 
ется для того, чтобы фирма 
.могла пользоваться стандар- 


том ЕОІ, даже если ее дело- 
вые партнеры по-прежнему 
пользуются бумажной доку- 
ментацией. 

ТНе Теіериііпв Ноіііпе, 
НоѵетЬег 12, 1991 

Со^пііо представила Насііо 
Тгапзтіззіоп Ші1 (КТО) для 
переносных компьютеров. 
КТО предоставляет пользо- 
вателям переносных РС 
доступ к мобильным сетям 
передачи данных. N061 
Ьезііе, управляющий марке- 
тингом формы Со^пііо, хочет 
связаться с разработчиками 
по поводу создания при- 
кладных программ. Устрой- 
ства пересылают данные со 
скоростью 6.000 бит в се- 
кунду, сообщениям для по- 
иска адресата в интерактив- 
ной сети требуется 7 секунд. 
Разница между КТО и мо- 
демом заключается в том, 
что КТО можно подсоеди- 
нить практически к любому 
устройству обработки дан- 
ных, включая крупные пер- 
сональные компьютеры, 
принтеры или пакетные сети 
передачи данных. С момента 
начала работы в августе, 
Со^піЮ подключила 20 ком- 
паний с примерно 200 тер- 
миналами. Теоретически су- 
ществующая радиосеть на 
УКВ частотах, которая к 
следующему марту должна 
охватить территорию с при- 
мерно 70% населения Вели- 
кобритании, может 

обслуживать около 70.000 
пользователей. 

ТНе Теіериііпк Ноіііпе, 
ИоѵетЬег 14, 1991 
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Кабели — 
это не совсем 
просто... 


“ Не забудь проверить кабели “. 

(7-ое правило пользователя РС) 

Приобретая персональный компьютер, редко кто за- 
думывается о разнообразных кабелях для подсоедине- 
ния периферийных устройств, входящих обычно в 
комплект поставки. Вспоминают о них лишь тогда, 
когда приподнятое настроение, вызванное удачной по- 
купкой, уже проходит и начинается рутинная повсед- 
невная работа. Выясняется, например, что длина ка- 
беля для подключения плоттера чуть меньше необхо- 
димой, а принтер, который предполагалось установить 
у самой стены (как всегда, мало места), из-за типа со- 
единителя на кабеле разместить, как хотелось бы, не 
удается. Влияние электромагнитных помех и шумов, 
вызванных работой различной электро- и радиоаппа- 
ратуры, часто сказывается на функционировании уда- 
ленных периферийных устройств. 

Нетрудно согласиться, что проблем может возник- 
нуть немало, хотя многие из них можно было бы 
предусмотреть заранее. Конечно, покупая компьютер, 
у, скажем так, не очень серьезной “фирмы 44 , вы вряд 
ли сможете сразу приобрести именно те кабели, кото- 
рые вам необходимы. Скорее всего вам смогут помочь 
немногочисленные официальные дистрибьюторы и 
производители компьютеров, появившиеся на нашем 
“узком 44 компьютерном горизонте. Для того чтобы вы- 
бирать, надо знать, как и из чего. 


Давайте, особенно не углубляясь в детали, погово- 
рим о кабелях для периферийных устройств. 

Обычно на вопрос — “Какие бывают кабели ? 44 — 
можно получить столь же оригинальный ответ — 
“Разные 44 . (Ну как не вспомнить диалог чеховских 
героев: “А какое правление в Турции? — Известно 
какое, турецкое 44 .) И, тем не менее, кабели 
действительно бывают разные, хотя, конечно, имеют и 
много общего. Кстати, не очень благозвучное слово 
“кабель 44 (если верить словарю) в переводе с 
голландского означает канат или трос. С помощью 
кабелей к компьютеру подключаются практически все 
периферийные устройства: клавиатура, монитор, 

мышь, модем, принтер, плоттер и т.п. Открыв крышку 
компьютера, можно обнаружить, что винчестер и 
приводы флоппи-дисков подключаются к 
соответствующим контроллерам также через кабели 
(правда, несколько иные). Для того чтобы 
разобраться, что же все-таки отличает и объединяет 
все эти кабели, рассмотрим, как устроен практически 
любой кабель. Это, во-первых, соединители 
(разъемы), находящиеся на двух концах кабеля, и, во- 
вторых, изолированные друг от друга проводники, со- 
единяющие эти разъемы. Причем все проводники мо- 
гут быть тем или иным образом заключены в металли- 
ческую оболочку (экран), а весь кабель может быть 
покрыт пластиковой защитной оболочкой. Таким обра- 
зом, друг от друга кабели могут отличаться типами со- 
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единителей на обоих концах кабеля, количеством 
используемых в кабеле проводников, тем, как эти про- 
водники связаны с контактами разных соединителей. 
Конечно же, кабели различаются и по длине, и еще 
ряду параметров, некоторые из которых мы постара- 
емся рассмотреть в дальнейшем. Итак... 

Соединители 

Соединители (разъемы) бывают двух видов — ро- 
зетки и вилки. Контактные выводы вилок выполнены 
обычно в виде небольших (возможно, позолоченных) 
штырьков, которые при соединении с однотипным 
разъемом (но уже вилкой) входят в соответствующие 
пазы ответных контактов. Впрочем, контакты и в ро- 
зетке, и в вилке могут быть выполнены в виде плоских 
пружинных пластин, но тогда формы самих соедини- 
телей таковы, что для обеспечения надежного кон- 
такта соединитель-вилка входит в соединитель-ро- 
зетку, например, как у разъемов типа Сепігопісз. Оте- 
чественные электронщики обычно называют соедини- 
тель-розетку “мамой", а соединитель-вилку — 
“папой", что вовсе не признак их сексуальной распу- 
щенности. Дело в том, что в техническом языке их 
западных коллег официально используются слова 
“та1е“ — для соединителей-вилок и "Іетаіе" — соот- 
ветственно для розеток. Таким образом, можно счи- 
тать, что соединители имеют “род". Сами 
соединители могут быть как разборными, так и 
неразборными (залитые в пластиковую оболочку — 
полная аналогия с вилками для бытовых 
электроприборов). Понятно, что и то и другое 
исполнение имеет как преимущества, так и 
недостатки. Если вы не собираетесь модифицировать 
схему соединения кабеля, то, вероятно, вам скорее 
подойдет неразборный соединитель. Если в кабеле 
используется несколько экранов, то более удачным 
будет разборный соединитель в металлическом 
корпусе. Ну, а о ремонтопригодности кабеля можно 
говорить, конечно, только в одном случае. Для хоро- 
шего заземления и надежного закрепления кабеля к 
устройству (или компьютеру) нужны два винта по 
краям соединителя. Эти винты могут быть под отверт- 
ку или могут иметь специальную накатанную головку 
((НитЬззсгешз), что позволяет закручивать их руками 
(это действительно удобно). Соединители же типа 
Сепігопісз фиксируются с помощью двух прижимных 
скоб. В общем случае все соединители, используемые 
для периферии персонального компьютера, можно 
подразделить на три группы. К первой, пожалуй, 
наиболее многочисленной, относятся соединители типа 
О-зНеІІ (в профиль напоминающие латинскую букву 
Э) различного размера и с разным числом выводных 
контактов. Они используются в кабелях для 
мониторов, модемов, принтеров (со стороны 
компьютера), плоттеров и т.п. Соединители типа 
Сепігопісз используются, как правило, в кабелях для 
принтеров и плоттеров с аналогичным интерфейсом 
(на приборной стороне, разумеется). И третий тип 


соединителей — трубчатый штекер, используется в 
кабелях для клавиатуры и для подключения мышек 
типа Виз Моизе. 

Проводники 

Каждый проводник в кабеле выполнен обычно из 
тонких медных проволочек (прядей), обладающих 
лучшими механическими свойствами, нежели один 
медный провод, такого же диаметра. Проводник, как 
правило, облужен оловом, что предохраняет его от 
окисления и облегчает пайку к выводному контакту 
соединителя. Для обозначения общего диаметра про- 
вода, используемого в кабеле, используется специаль- 
ный номер толщины (“у них"), обычно это номера 26 
или 24, реже 28. Причем, чем тоньше провод, тем 
больше номер. Использование более толстых проводов 
связано не только с механической прочностью, но в 
первую очередь, конечно, с меньшим удельным сопро- 
тивлением, что особенно важно для длинных кабелей. 
Каждый провод обычно изолирован от других поли- 
хлорвиниловой оболочкой (РоІуѴіпіІ СЫогісІе, РѴС). 
Для удобства распайки и контроля, изоляция проводов 
окрашивается в различные цветовые оттенки. Для 
длинных кабелей особую роль играет емкость кабеля, 
образующаяся между проводниками, где роль диэлек- 
трика выполняет их изоляция. Чем ниже емкость ка- 
беля, тем более высокочастотные сигналы по нему 
можно передавать. Уменьшить емкость, как известно, 
можно, уменьшив величину диэлектрической проница- 
емости материала изоляции. Поэтому для 
"низкоемкостных" (Іо^-сар) кабелей в качестве мате- 
риала изоляции используется полиэтилен. Для этого 
случая также подходят более "толстые" кабели (с 
меньшим номером толщины, например, 24). Внешняя 
фторопластовая оболочка для кабелей используется в 
случае их применения в промышленных помещениях 
(фторопласт, в отличие от РѴС, при горении не выде- 
ляет токсичных веществ). Правда, не все кабели 
имеют пластиковую защитную оболочку. У плоских 
ленточных кабелей, служащих, например, для соеди- 
нения винчестера со своим контроллером, такой обо- 
лочки нет. Эти кабели более дешевы, но предназна- 
чены для работы только на небольших расстояниях. 


Экранирование 

Кроме оболочки из пластика, кабели могут иметь 
одну или несколько оболочек, выполненных из токоп- 
роводящего материала: медная оплетка, слои алюми- 
ниевой фольги или все вместе. Это и есть экранирова- 
ние кабеля. Экран (экраны) должен быть обязательно 
заземлен — незаземленный экран резко увеличивает 
емкость кабеля, так что эффективность его использо- 
вания в этом случае может быть с точностью до на- 
оборот. Функционально экранирование решает, как 
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правило, две задачи. Во-первых, экран препятствует 
влиянию внешних электромагнитных полей на полез- 
ные сигналы, передаваемые по кабелю. Источниками 
этих полей могут быть различные электрические ма- 
шины, лампы “дневного 44 света и т.п. (Еіесіго 
Ма^пеііс Іпіегіегепсе, ЕМІ). И, во-вторых, 
экранируется создаваемое в самом кабеле 
электромагнитное поле, которое является источником 
радиопомех (Кабіо Ргедиепсу Іпіегіегепсе, КРІ). 
Необходимо помнить, что медная оплетка в качестве 
экрана лучше работает с низкочастотным шумом, а 
алюминиевая фольга — с высокочастотным. Если 
честно, то большинство периферийных устройств, 
расположенных вблизи компьютера, мало 
чувствительны к внешним (конечно, несильным) 
помехам и вполне надежно выполняют свои функци- 
ональные обязанности. Это касается клавиатуры, мо- 
нитора, модема, близко расположенных принтера и 
плоттера. Однако, если речь идет об удаленном 
устройстве (о том же принтере), то над экранирова- 
нием стоит подумать. Хороший эффект 
экранирования дают витые пары проводов в кабеле, 
так как это уменьшает взаимное влияние сигналов 
друг на друга. Но даже в таких кабелях витые пары 
размещают иногда в отдельный экран из фольги. 
Следует помнить, что для больших расстояний лучше 
использовать кабели экранированные, с толстым 
сечением провода и низкой удельной емкостью. 
Стандартный кабель имеет удельную емкость порядка 
100 пикофарад на метр, для 1о>ѵ-сар кабеля это 
значение должно быть раза в три меньше. 

Кабели для последовательной связи 

Последовательные кабели имеют много названий 
(баіа ЪіМѵізе и т.п.) и соединяют большинство пери- 
ферийных устройств компьютера: клавиатуры, мо- 
демы, мыши, принтеры и плоттеры (с последователь- 
ным интерфейсом), также они могут использоваться 
для связи компьютеров друг с другом (небольшие ло- 
кальные сети). Каждое устройство обычно требует 
своего типа кабеля. Если говорить о наиболее распро- 
страненном последовательном интерфейсе К5-232С 
(ЕІА-2320), то типовым соединителем для ІВМ 
РС/ХТ и Р8/2 является Ц-зЬеН, а точнее ОВ-25 (25 
контактов), а для ІВМ РС/АТ используется, как пра- 
вило, ИВ-9 (9 контактов), хотя возможен вариант с 
ОВ-25. Стандартным для “писишек 44 ІВМ является 
решение, когда блочным соединителем служит вилка 
(таіе), а на кабеле — розетка Цетаіе). Для персона- 
лок других фирм это не всегда так (например, Тапбу 
или ЬаЫат). В обозначении кабеля типа М/М или 
М/Р первая буква говорит о “роде 44 соединителя со 
стороны РС, вторая — со стороны устройства (таіе- 
таіе, таіе-іетаіе). Уровни электрических сигналов в 
кабелях для последовательной связи достаточно высо- 
кие (+12 или -12 вольт), а скорости передачи доста- 
точно низкие (300 - 9600 бит/с, может быть, правда. 


и выше), поэтому экранирование обеспечивает 
надежную передачу данных на больших расстояниях 
(до 60 метров). Кстати, если вы используете принтер 
с последовательным интерфейсом, то неплохо бы 
лишний раз заглянуть в техническую документацию, 
так как в зависимости от фирмы-изготовителя в ка- 
беле могут использоваться дополнительные соединения 
(перемычки). 

Соединители в кабелях для клавиатуры — это 
обычно трубчатые штекеры с пятью (для РС/ХТ/АТ) 
или шестью контактными выводами (для Р8/2). 
Длина такого кабеля обычно не превышает двух-трех 
метров. 

Кабели для параллельной связи 

Практически любой персональный компьютер имеет 
кабель для параллельной связи. Это кабель для прин- 
тера с интерфейсом типа Сепігопісз. Кстати, этот ин- 
терфейс используют многие планшетные плоттеры 
(формата АЗ, А4). Соединитель на этом кабеле со 
стороны компьютера — обычно розетка ОВ-25, а на 
стороне принтера — 36-контактный разъем-вилка 
типа Сепігопісз. Эти кабели могут иметь как 18, так и 
25 проводников, однако, работают они со всеми прин- 
терами, изготовленными в США. Интерфейс Сепіго- 
пісз использует сигналы транзисторно-транзисторной 
логики (ТТЬ) с уровнями 0 или +5 вольт. Поскольку 
частота передаваемых сигналов может достигать де- 
сятков килогерц, длина таких кабелей обычно не пре- 
вышает трех метров. Как правило, для линий данных 
и строб-сигнала в кабеле используются витые пары. 

Кабели для мониторов различаются в зависимости 
от типа используемого монитора. Имеется два стан- 
дарта на соединители в таких кабелях: 15-контактный 
ОВ-зНеІІ для мониторов, использующих аналоговые 
сигналы (ѴСА, ЗирегѴСА, 85 14/ А и ХСА), и 9-кон- 
тактный ОВ-зНеІІ для мониторов, использующих 
ТТЬ-сигналы (МЭА, ССА и ЕСА). Как правило, на 


НАШИ ПРОГРАММНЫЕ ПРОДУКТЫ - КЛЮЧ К 
УСПЕШНОМУ РЕШЕНИЮ ВАШИХ ЗАДАЧ! 

Центр “Интерфейс 44 предлагает уникальные пакеты для 
ІВМ РС/ХТ ДТ: 

РОКС НА РН — новая графическая бибил отека для Фортрана-77 (научная, 
деловая, интерактивная графика); 

СКАРН* — расширенная графика на языке Си (самая мощная 
графическая библиотека для Си, призер конкурса “Борланд-Контест-91); 

15Р*(Іп1егасІіѵе 5і&па1 Ргосезхіп^) — диалоговая система моделирования и 
цифровой обработки сигналов; 

Р К ОТ ЕСТ* — комплекс программ защиты от несанкционированного 
копирования. 

•) Поставка в исходных текстах на Си. 

Стоимость пакетов сравнима с зарплатой инженера или 
научного работника. Частным лицам скидка до 50%. 
ВЫСОКОЕ КАЧЕСТВО И ДОСТУПНЫЕ ЦЕНЫ — 

ЭТО СТИЛЬ НАШЕЙ РАБОТЫ! 

По запросу вышлем описание, условия поставки, 
демодискету: 142432 , Черноголовка , а/ я 33, ННЦ АН 
СССР, “ Интерфейс “. 
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КАБЕЛИ — ЭТО НЕ СОВСЕМ ПРОСТО 


кабелях мониторов имеются специальные фильтры, 
уменьшающие высокочастотные помехи в сигналах 
изображения. Длина таких кабелей также не превы- 
шает двух-трех метров. 

ТиНі-ГгиНі, или “всякая всячина* 4 

Производители компьютеров обычно вместе с 
основным предлагают многочисленное дополнительное 
оборудование, среди которого не последнее место за- 
нимают и кабели специального назначения. Напри- 
мер, для установки принтера непосредственно у стены 
помещения применяется специальный кабель 
Ап^іе (вывод проводов кабеля перпендикулярен плос- 
кости соединителя). Для того чтобы соединить два 
компьютера через последовательные порты, обычный 
кабель для модема, конечно, не подойдет, необходим 
специальный “нуль-модемный 44 (Ыиіі Мобеш) кабель. 
Имеются различного вида удлинительные кабели, ко- 
торыми можно наращивать основной. Правда, приоб- 
ретая такой кабель, не следует забывать о двух вещах: 
во-первых, о “роде“ (таіе-іешаіе) соединителей удли- 
няемого кабеля, и, во-вторых, о том, что один длин- 
ный кабель внесет меньше искажений в сигнал, не- 
жели два кабеля, соединенных вместе. При длине ка- 
беля более 4,5 метров экранирование просто необхо- 
димо. При работе с устройствами, позволяющими, на- 
пример, использовать один принтер для нескольких 
компьютеров, также необходим набор расширительных 
кабелей. Кстати, такие устройства носят милое на- 
шему сердцу название “коллективизаторов 44 . Предла- 


гаются и специальные кабели (длина которых ограни- 
чена иногда длиной используемых соединителей) для 
изменения “рода 44 кабеля; имея, например, 
“неправильный 44 кабель с соединителем-розеткой и 
используя специальный переходник, несложно полу- 
чить необходимый соединитель-вилку. Для любителей 
работать с комфортом (или если системный блок за- 
громождает рабочий стол), предусмотрен удлинитель- 
ный кабель к клавиатуре длиной обычно не более трех 
метров. То есть продумано многое, даже то, от чего 
мы пока еще достаточно далеки. 

Резюмируя вышеизложенное, не грех, как гово- 
рится, вспомнить старую студенческую шутку о том, 
что “радиоэлектроника — это наука о контактах 44 . 
Очень не рекомендуется выдергивать (как правило, 
закрепленный винтами) кабель не за его соединитель. 
Маловероятно, что сорвется резьба винтов, а вот, что 
“отлетит 44 какой-нибудь проводник — это реально. 
Ведь если соединитель неразборный, с кабелем, по-ви- 
димому, придется расстаться. Если вы используете 
удаленный принтер, проложите соединительный ка- 
бель так, чтобы он хотя бы не мешался под ногами, 
иначе вам можно гарантировать немало “приятных 44 
минут. Поскольку в рамках одной статьи практически 
невозможно изложить даже весь материал, связанный, 
например, с экранированием, то перед приобретением 
компьютера (безусловно, в комплекте с кабелями) не- 
плохо проконсультироваться со специалистами, если 
вы в чем-то не вполне уверены. Поверьте, кабели — 
это не совсем просто... 

А.Борзенко 


Смерть Максвелла может 
замутить воды американского 
он-лайнового бизнеса 

Смерть магната прессы Роберта 
Максвелл (КоЬеП Мах\ѵе11) может при- 
вести к новой перетряске среди он- 
лайновых служб США. Махѵѵеіі созда- 
вал маленькую империю он-лайновых 
служб, включающую в себя ОГЛсіаІ 
Аігііпе Сиісіе, бывшие службы ВК5 и 
ОгЪі!, Ргепіісе-Наіі ІпГогтаІіоп, №ііопа1 
Кедоіег и 8іапдаг<1 Каіе & Эаіа. Мак- 
свелл был также владельцем издатель- 
ства МастШап, в которое входило (}ие, 
ведущее издательство книг по компью- 
терам. Целью, которую поставил себе 
Махмѵеіі, было образовать единый кон- 
гломерат из этих разноообразных 
предприятий, предлагающий бестсел- 
леры в он-лайновом виде и на ком- 


пакт- дисках и связывающий между 
собой различные службы. Но работа 
продвинулась недалеко, а сообщения в 
прессе указывают на то, что вся его 
финансовая империя была близка к 
катастрофе. Компании могут быть про- 
даны, по отдельности или все вместе. 
Пока неясно, какие долговые обяза- 
тельства за ними остались. 

ТНе ТеІериііп% Ноіііпе , 
ЫоѵетЬег 12 , 1991 

Владельцы ВВ8 опасаются 
судебных исков 

Осіуззеу, ВВЗ “для взрослых 44 , опа- 
сается судебных исков после недавней 
шумихи вокруг РгосИ^у. 29 октября 
Анти-Диффамационная Лига Бнай 
Брит заявила, что обнаружила антисе- 


митские материалы, распространяемые 
по электронным бюллетеням РгосН^у, и 
РгосП^у с готовностью ужесточила цен- 
зуру — теперь запрещены оскорбления 
как личные, так и в адрес различных 
групп. Владелец Осіуззеу МісЬаеІ АІІеп 
сказал, что весь шум был вокруг сооб- 
щений, отправленных пользователями, 
а система не при чем. Он озабочен 
возможностью того, что кто-нибудь 
возбудит против его бюллетеня иск. 
Несмотря на это, Осіуззеу собирается 
прекратить цензурировать сообщения, 
помещаемые в определенные открытые 
разделы и по спорным вопросам. Пла- 
нируется также создание раздела по 
обсуждению абортов. 0(іуз$еу доступен 
через СотриЗегѵе или напрямую по 
818/358-6968. 

ТНе Теіериііпк Ноіііпе , 
ИоѵетЬег 14, 1991 
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Итак, после долгих сомнений вы, 
наконец, решились написать большую 
программу. Это может быть, например, 
СУБД или некоторая интегрированная 
система. Перед вами сразу встает 
множество проблем, и одна из них 
заключается в том, чтобы обеспечить 
возможность расширения функций 
вашей системы без переписывания 
текстов программ. 


Импорт объектов 
из внешней программы 

на ТигЬо РазсаІ 


Обычно эта проблема решается при помощи макро- 
функций или макроязыка, позволяющего пользователю 
создавать свои собственные приложения. Примером 
программы с развитым макроязыком может служить 
текстовый редактор МиШЕсШ, в котором все операции 
по управлению текстом могут быть выполнены с по- 
мощью программы -мак роса. Единственный недостаток 
этого метода заключается в сложности его реализации. 
Действительно, если вы решите включить в вашу про- 
грамму макроязык, то вам придется писать интерпре- 
татор и отладчик, что не так просто. 

Чтобы не связываться с интерпретатором, можно 
написать собственную библиотеку функций, которую 
затем использовать в различных языках программиро- 
вания. В этом случае программист сможет создавать 
приложения к системе, используя готовый компилятор 
и создавая исполняемые (.ЕХЕ) модули программ- 
приложений. Однако каждая такая программа должна 


будет содержать в себе весь набор базовых функций 
вашей системы (рис. Іа). 

Другое решение заключается в том, что все прило- 
жения могут запускаться из главной программы и вы- 
зывать из нее (главной программы) все необходимые 
процедуры. Другими словами, программы-приложения 
будут использовать код главной программы для до- 
ступа к базовым операциям (рис. 1Ь). Примером 
такой системы может служить МісгозоН МпсІоѵѵз. Про- 
граммы, написанные для этой системы, используют 
базовые операции для того, чтобы в графике изобра- 
жать окна, меню и диалоговые панели. 

Хорошая идея, но как ее реализовать? Первое, что 
приходит в голову, это воспользоваться системой пре- 
рываний. Главная программа перехватывает свободное 
прерывание, а программа-приложение затем вызывает 
его для доступа к базовым функциям. Однако тут мы 
попадаем в странное положение: обе программы 
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а) Независимая программа- 
приложение дублирует все 
базовые функции . 


640к 



Ь) Программа-приложение 
вызывает базовые функции из 
главной программы. 


Рис. 1 . Сравнение двух способов организации доступа к базовым 
функциям из программы -приложен ия. 


(главная и приложение) пишутся на языке высокого 
уровня с использованием объектно-ориентированного 
программирования, а связь между ними осуществля- 
ется примитивно, при помощи регистров и прерыва- 
ний. Было бы гораздо лучше, если бы программа-при- 
ложение могла обращаться к процедурам или 
объектам главной программы так же, как она 
обращается к собственным процедурам и объектам. 
Для этого ей необходимо сообщить адреса всех 
базовых процедур, которые она будет использовать, и 
это можно легко сделать, используя объектно- 
ориентированный подход. 

Давайте с вами напишем программу МАШ, которая 
будет содержать некий базовый объект (например, 
базу данных ВА8Е), и попробуем организовать доступ 
к методам этого объекта из программы-приложения, 
которую назовем СНІЫЭ. Для начала нужно вспом- 
нить, что при компиляции программы на Разсаі все 
обращения к невиртуальным методам объектов заме- 
няются на вызовы процедур с явно указанными адре- 
сами. Поэтому, если мы хотим изменять эти адреса в 
процессе работы программы, мы должны объявить все 
методы объекта ВАЗЕ виртуальными. Для каждого 
типа объекта, имеющего виртуальные методы, Разсаі 
создает таблицу виртуальных правил (ѴМТ), которая 
содержит адреса всех виртуальных методов объекта. 

Теперь нам понадобится создать два модуля 
(библиотеки). Первый модуль (назовем его ВА8Е1) 
будет содержать полное описание объекта ВАЗЕ со 
всеми методами. Второй модуль (ВА8Е0) будет со- 
держать только описание объекта ВАЗЕ в разделе іп- 


ІеіТасе, а вместо процедур в разделе 
ітріетепіаііоп будут стоять “пустые“ 
заголовки и пустые операторы Ье§іп епб. 
Первый модуль будет использован при 
компиляции программы МАШ, а второй — 
при компиляции программы СНІІТ). Таким 
образом, программа СНІЫ> сможет 
использовать объект ВАЗЕ, который описан 
в модуле ВАЗЕО. Для этого типа объекта 
будет создана таблица ѴМТ, в которой 
будут записаны адреса “пустых“ методов 
этого объекта. Адрес этой таблицы можно 
получить при помощи стандартной 
функции ТуреОГ Если бы мы могли 
заменить этот адрес в объекте программы 
СНІІТ) на адрес аналогичной таблицы из 
программы МАШ, то мы бы достигли 
желаемого результата, но, к сожалению, 
этого сделать нельзя, потому что объект 
хранит только смещение таблицы ѴМТ. 
Следовательно, единственный способ 
переадресовать обращение к методам объ- 
екта — полностью скопировать содержимое 
таблицы ѴМТ программы МАШ в 
аналогичную таблицу программы СНІІЛ). 

Но это еще не все. Посмотрите на 
рисунок 1Ъ. Вы видите, что программа 
СНІИ) вызывает процедуры из программы 
МАШ. Теперь представьте, что некоторая процедура 
пытается отвести память под свои переменные путем 
вызова стандартной процедуры СеіМеш. Она будет 
вызвана из области программы МАШ и попытается 
выделить память в области, зарезервированной 
программой МАШ, которая на время выполнения 
программы СНИТ) будет уменьшена до минимума. 
Для того чтобы процедуры из программы МАШ могли 
отводить память в области, зарезервированной про- 
граммой СНИЛ), мы должны присвоить переменным 
НеарРІг и НеарОг§ программы МАШ значения соот- 
ветствующих переменных программы СНІИ). 

Чтобы программа СНІІТ) могла совершить все вы- 
шеперечисленные действия и получить доступ к мето- 
дам объекта ВАЗЕ, программа МАШ должна создать 
таблицу настройки, которая должна содержать следу- 
ющие сведения: 

- адрес переменной НеарРіг; 

- адрес переменной НеарОг^; 

- длина таблицы ѴМТ объекта ВАЗЕ; 

- адрес таблицы ѴМТ объекта ВАЗЕ. 

Как вычислить длину таблицы ѴМТ? Смотрите на 
рисунок 2: таблица ѴМТ содержит размер объекта (он 
занимает 16 бит), отрицательный размер объекта для 
контроля инициализации (еще столько же) и список 
полных адресов всех виртуальных методов. Следова- 
тельно, длина таблицы ѴМТ вычисляется как: 

ѴМТ_5Іге : = 4 + ЗіхеСИЧРоіпІег) * МеІН_Ыиш; 

где Ме1Н_Ыипі — количество виртуальных методов 
объекта. Количество методов не удается получить 
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Память до настройки 


Память после настройки 


<< Программа СНІЮ >> 640 



Экземпляр объекта Вазе 

; 1 


Таблица ѴМТ "пустого” объекта 




Указатель на Неар (СИіІсІ) 


ігТШЯИЯЬд к 


к 

Код программы 




п 

(объекта Вазе нет) 

а 



и 

р 

<< Программа МАІЫ >> 

В 


0 

в 

Указатель на Неар (Маіп) 



т 

Таблица настройки 




ь 

Таблица ѴМТ объекта Вазе 


шЯИЯ Е2Е 


— 

а 

Д 

Р 


4ММПММШЖ 


Код программы: е 




методы объекта Вазе с 






ВІОЗ, эоз 



— > 
п 

Вектор $61 



640 



ВІ03, 003 


Вектор $61 
О 1 


Рис. 3. Настройка программы-приложения на работу с главной программой. 


стандартной функцией, поэтому в качестве этого па- 
раметра лучше использовать константу. 


Размер 

объекта 

Отриц . 

размер 


Адрес 1 метода 


2 байта 
2 байта 
4 байта 


Рис. 2. Структура таблицы ѴМТ. 

Из таблицы настройки программа СНІЫ) узнает все 
необходимое для того, чтобы настроить себя на работу 
с программой МАШ. Осталось сообщить ей адрес этой 
таблицы. Этот адрес программа МАШ поместит в один 
из свободных векторов прерываний (например, $61). 
Программа С НІИ) должна прочитать этот вектор и 
проверить его правильность, для чего в таблице на- 
стройки предусмотрен заголовок. 

Сразу после запуска программа СН1Ы) должна про- 
читать содержимое вектора прерывания, проверить, 
лежит ли по этому адресу таблица настройки и, если 
это так, заменить содержимое таблицы виртуальных 
правил (ѴМТ) “пустого" объекта на содержимое ана- 
логичной таблицы главной программы. После этого 
программа СНІІЛ) должна переслать содержимое пе- 
ременных НеарРіг и НеарОг^ в программу МАШ и 
вызвать конструктор экземпляра объекта ВАЗЕ (при 
этом адрес таблицы ѴМТ с новыми адресами методов 
будет помещен в экземпляр объекта). На этом закан- 
чивается настройка программы СНПТ) (рис. 3). 

После того, как программа СННЛ) завершит свою 
работу и управление вернется в программу МАШ, не- 
обходимо вернуть прежние значения переменным 
НеарРіг и НеарОп» (их нужно сохранить перед вызо- 


вом программы СННЛ)) и освободить занятый вектор 
прерывания. 

Осталось добавить, что если вы хотите организовать 
импорт нескольких объектов, то вам придется реорга- 
низовать таблицу настройки, чтобы в ней можно было 
передавать параметры нескольких объектов. Для этого 
в начале таблицы можно указать количество импорти- 
руемых объектов. 

Остается открытым вопрос об использовании этого 
метода вместе с оверлейными модулями. Для того 
чтобы импортировать оверлейный объект, наверное, 
можно передать параметры буфера оверлеев так же, 
как мы передали параметры Неар. 

Все, что здесь написано, я проверил на практике, 
написав программы МАШ и СНІЫ), которые успешно 
работают, демонстрируя правильность сделанных вы- 
водов. Ниже приведен текст обеих программ. Для 
удобства использования я выделил все функции на- 
стройки в отдельный модуль ТІШЕ. Модуль ВАЗЕ1 не 
приведен для экономии места; он отличается от мо- 
дуля ВАЗЕО тем, что в разделе ітріетепіаиоп опи- 
сана конкретная реализация объекта ВАЗЕ. 


С. Кучеров 


{ 

{ Модуль настройки ТІ^Е 

( 

ипіі Типе; 
іпіегіасе 


іуре 

РошіРіг = л роіпІег; 
ТипеРіг = '"ТипеТаЫе; 

Типе ТаЫе « гесопі 
Неасі : іпіе^ег 
РНеарОг^ : РоіпіРіг; 
РНеарРіг : РоіпіРіг; 
ѴМТРіг ■ іпіег. 


{ Таблица настройки объекта } 
{ Заголовок всегда -1 } 

{ Указатель на Маіп.НеарОг^ } 

{ Указатель на Маіп.НеарРіг } 

{ Указатель на Маіп.ѴМТ } 


} 

) 

} 
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ИМПОРТ ОБЪЕКТОВ ИЗ ВНЕШНЕЙ ПРОГРАММЫ НА ТШВО РАЗСАЬ 


ѴМТЗіге : шотхі; { Размер таблицы Маіп.ѴМТ } 

епсі; 

{ •••••• Процедуры, вызываемые из Маіп •••••• } 

ргосесіиге 5аѵеИеар(ѵаг Т:Типе_ТаЫе); { Сохранитъ параметры Маіп.Ьеар } 
ргосесіиге Ке$1огеНеар(ѵаг Т:Типе_ТаЫе); { Восстановить параметры Маіп.Ьеар } 

{ •••••• Процедуры, вызываемые из СЬіІсі •••••• } 

ргосесіиге СЬапвеНеар(ѵяг Т:Типе_ТаЫе); { Записать параметры СЬікШеар } 

{ в Маіп.Неар } 

ргосесіиге СоруѴМТ(ѵаг Т:Типе_ТаЫе; Ѵріпроіпіег); { Записать Маіп.ѴМТ } 

{ в сыы.ѵмт } 

ітріетепіаііоп 
и$е$ Е)ос; 
ѵаг 

ОкіНеарРіг, 

ОМНеарОг^ : роіпіег, 

ргосеёиге ХаѵеНеар; 

Ьерп 

ОІсіНеарРіг: * НеарРіг; 

ОИНеарОг# * НеарОгр 
Т.РНеарОг& « @НеарОгр 
Т.РНеарРіп * @НеарР1г, 
епсі; 

ргосесіиге КеаіогеНеар; 

Ьерп 

НеарРіп * ОкіНеарРіг; 

НеарОгд: = ОкШеарОг^; 

Т.РНеарОгр = піі; 

Т-РНеарРіг = піі; 
епсі; 


сасе ЕкмЕггог о( 

2 : ѵгіІе(” Ошибка: не найден файл СНІЮ.ЕХЕ); 

3 : ѵгііе(”Ошибкв: путь не найден ); 

5 : ѵгііе(” Ошибка: файл недоступен”); 

8 : ѵгііе(*Ошибка: не хватает памяти, чтобы запустить СНІШ.ЕХЕ*); 
епсі; 
епсі; 

Ье&іп 

{ — Инициализация таблицы библиотеки — ) 
ѵііЬ ТТ сіо Ьерп 
Неасі : * -1; 

РНеарОг^ : - піі; 

РНеарРіг : - піі; 

ѴМТРіг : « ТѴреОГ(Ваае); 

ѴМТХіте : = 4 + $І 2 еО((роіпіег) • МеіЬоск; 
епсі; 

{ — Записать параметры главного модуля — ) 

5аѵеНеар(ТГ); 5е1ІпіѴео($61А<і<іг(ТТ)); 

{ — Запустить программу СЬіІсі — ) 

ЗѵарѴесіоге; 

Ехес(”СНІШ.ЕХЕу”); 

ЗлѵарѴесіоге; 

{ — Восстановить параметры главного модуля — } 

Ке$1огеНеар(ТТ); 5е1ІпіѴес(Іб1,пі1); 
епсі. 



ргосесіиге СЬап^еНеар; 

Ъе&іп 

ѵііЬ Т сіо Ъе$іп 
РНеарОг^: = НеарОг^; 

РНеарРіг^: = НеарРіг 
епсі; 
епсі; 

ргосесіиге Сору V МТ; 

Ье&іп 

ѵііЬ Т сіо Моѵе(ѴМТРіг\ѴрІг\ѴМТ5І2е); 
епсі; 
епсі. 

{ } 

{ Главная программа } 

{ } 

иве* Сгі, Е)о$, Типе, Ва$е1; 

{$М $400,0,0} 


ѵаг 

ТТ : ТипеРіг, { Указатель на таблицу настройки } 

В : Ьа$е; { Экземпляр импортируемого объекта } 

біпсііоп Ргопз Маш : Ьооіеап; 
ѵаг Р ; роіпіег, 

Ье&ш 

ОеІІпіѴес($61,Р); ТТ: = Р; { Получить адрес таблицы настройки } 

Ргот_Маіп: = Ігие; 

ІГ (ТТ = піі) ог { Если вектор пуст } 

(ТГ'.НеасІ < > -1) { или не указывает на таблицу, } 

іЬеп Ргош Маш: = Саке { то настройка невозможна } 

еке Ье^ш 

СЬяп^еНеарСГР); { переслать параметры Неар в программу МА1И } 
СоруѴМТ(ТТ',ТуреОС(Ва5е)); { скопировать таблицу ѴМТ из } 

{ программы МА1И в аналогичную таблицу СНІЬЕ) } 

епсі; 

епсі; 


ѵаг ТТ : Типе ТаЫе; { таблица настройки } 

5 : 5ІГШ&; 
і : Ьуіе; 

СОП5І 

МеіЬоск = 10; { количество методов объекта } 

ргосесіиге ѴѴгіІеЕггог, 

Ье^іп 

ТехіАИг = $8С; доіоху(2,4); 


Ьеціп 

іС поі Ргот_Маіп ІЬеп Ье$ш 

ѵѵгіІе1п(' Программа должна быть запущена из главного модуля!”); 

НаИ; 

епсі; 

В.іші; { Запуск конструктора объекта } 

Обращение к экземпляру объекта ВА5Е. ••} 

Все методы этого объекта будут вызваны из программы МАІІЧ. ••} 

епсі. 


Эффективно, недорого, просто 

— ЛВС ЗіагШге — 

идеальный способ объединения персональных компьютеров 
Вашего офиса в локальную сеть! 

Под управлением М8-008 сеть ЗіагШге позволит использовать 
один из персональных компьютеров в качестве файл-сервера или 
превратить его в привилегированную станцию, имеющую доступ 
к дисковой памяти всех остальных машин. 

В сочетании с ОС Ыоѵеіі Ыеі\ѵаге сеть 8іаг\Ѵіге обеспечит доступ 
к ресурсам ЛВС типа АгсЫеі, ЕіНегМеІ через свой файл-сервер. 



АКЦИОНЕРНОЕ ОБЩЕСТВО 
103706 Москва, пл. Куйбышева, 1, тел.: 29Ѳ-8&88 


8іаг}Ѵіге: 

топология — звезда (сервер+7 станций); 
интерфейс — К8-232С; 
скорость передачи — 1 1 5200 бит/с; 
среда передачи — витая пара; 
резидентный объем ОЗУ — не более 64 К. 
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Хѵдк нельзя узнать вкус напитка по 
одной лишь его этикетке, едва ли 
можно выбрать среду программирования 
без практической работы в ней, только 
путем чтения спецификаций, пресс- 
релизов и журнальных обзоров. Поэтому 
в данной статье предлагается не обзор 
возможностей ТигЪо РазсаІ для Шпдот, 
а последовательное рассмотрение 
конкретного примера программы 
ЗузСоІог, которая позволит вам 
устанавливать системные цвета среды 
Місюзоф Шпдот. 


Объектно-ориентированное 

программирование 

в среде ТигЬо РазсаІ для Ѵ/іпсіоѵ/з 


С появлением новой версии ТигЬо РазсаІ, предна- 
значенной для создания программ в среде МісгозоН 
АѴіпбо^з, легко представить себе, как могла бы выгля- 
деть коммерческая телереклама этого программного 
продукта. Например, один программист подменяет 
другому дистрибутив ТигЬо РазсаІ для АѴіпскнѵз копией 
МісгозоН ЗЭК, а когда жертва в отчаянии говорит 
окружающим “сдаюсь" и получает назад свой дистри- 
бутив, на экране появляется заставка ТигЬо РазсаІ, и 
счастливый обладатель пакета восклицает: “Ха-ха, я 
наконец-то получил самое лучшее в мире средсгво для 
программирования в >Ѵіпс1одѵз!“. 

Однако вряд ли коммерческая реклама поможет 
программисту решить, действительно ли выбор в каче- 
стве средства создания программ системы ТигЬо РазсаІ 
для ^Ѵішкиѵз (ТР>Ѵ) является верным. В конце концов, 
так же, как нельзя узнать вкус напитка по одной 
лишь его этикетке, едва ли можно выбрать среду про- 
граммирования без практической работы в ней, только 
путем чтения спецификаций, пресс-релизов и жур- 
нальных обзоров. Поэтому в данной статье предла- 
гается не обзор возможностей ТРАѴ, а последователь- 
ное рассмотрение конкретного примера программы 
ЗузСоІог на языке ТигЬо РазсаІ для >Ѵіпбодѵз, которая 
позволит вам устанавливать системные цвета среды 
МісгозоН >Ѵіпскж5. 


Изучая исходный текст программы ЗузСоІог, вы по- 
знакомитесь с Объектной Библиотекой для >Ѵіпс1о^ѵз 
(ОЬіесі АѴіпсІодѵз УЬгагу, ОШЛ, входящей в состав 
ТР>Ѵ, и получите представление о том, как объектно- 
ориентированный подход позволяет снизить громозд- 
кость, обычно присущую программам для АѴіпсіоаѵз. 
Попутно вы получите полезную утилиту с исходным 
текстом, которую вы сможете свободно распространять 
(в том числе и по ВВЗ) и вообще делать с ней все, что 
угодно. 

Компиляция программы ЗузСоІог 

Исходные тексты программы ЗузСоІог и файла ре- 
сурсов приводятся в конце настоящей статьи. Загрузив 
редактор ТР^, создайте файл ЗѴЗСОЬОЯ.РАЗ и набе- 
рите исходный текст программы; затем таким же 
образом введите текст файла ресурсов ЗѴЗСОШЯ.ЯС. 

Ввод программ вручную займет около 5 часов; если 
у вас есть модем, вы можете получить архив с исход- 
ными текстами на ВВЗ. (В нашей стране исходные 
тексты программы ЗузСоІог можно получить, подклю- 
чившись к ВВЗ СП “Диалог". Имя ВВЗ — ‘МѴ Оіа- 
Іо^ие \ѴН ВВЗ“, московский телефон (095) 329-2192, 
область 9 (М3 >Ѵіпсіоаѵз Рііез). Эта ВВЗ работает круг- 
лосуточно все дни недели. Исходные тексты про- 
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ОБЪЕКТНО-ОРИЕНТИРОВАННОЕ ПРОГРАММИРОВАНИЕ В СРЕДЕ ТШВО РАЗСАЬ ДЛЯ 1УПШСИѴ8 



граммы 8узСо1ог находятся в архиве 
8Ѵ8-СОШК..Ь2Н, (прим, перев.). 

Раскрыв архив, вы получите три файла, нуж- 
ных для компиляции программы 8узСо1ог: 
8У8СОЬ(Ж.РА8, 8У8СОЬ(Ж.КС и 

8У8СОШК.ІСО. 

В файле 8У8СОШК..РА8 содержится исход- 
ный текст программы 8узСо1ог на Разсаі. Файл 
8У8СОШК.ІСО содержит пиктограмму (см. 
рис. 1), которая отображается при установке 
программы 8узСо1ог в группе МісгозоН >Ѵіпсіоте, 
при минимизации ее окна и в диалоговом окне 
“АЬоиі...“. 

Файл 8У8СОШК.КС называется файлом опи- 
сания ресурсов. Ресурсы программы для 
>Ѵіп(1о\ѵз — это данные, которые используются 
функциями АУіікІофз для отображения диалого- 
вых окон, меню, пиктограмм и пр. Файл описа- 
ния ресурсов — это текстовый файл, в котором 
при помощи специальных операторов описаны 
ресурсы МісгозоН АѴіпсктз. Ресурсы программы 
для АѴіпсіо^ѵз включаются компоновщиком в гото- 
вый исполняемый модуль на самом последнем 
этапе создания программы. Компоновщик запи- 
сывает ресурсы в исполняемый файл в двоичном 
виде (файл *.КЕ8, который получается из файла 
*.КС путем компиляции компилятором ресурсов фир- 
мы МісгозоН). Стандартные функции обслуживания 
диалога, известные под собирательным названием Ин- 
терфейс Программирования Приложения (Арріісаііоп 
Ргойгашшіп^ Іпіегіасе, АРІ), а также другие функции 
МісгозоН АУіпсІошз доступны программам на ТР^ из 
двух библиотек (ТРШ — >&ЧпТуре5 и ^ЧпРгосз. 

Для того чтобы скомпилировать файл 8У8- 
СОШК.К.С, в первой строке измените путь так, чтобы 
он указывал на тот каталог, где у вас находится файл 
\ѴІЫОО\Ѵ8.Н, после чего введите команду 

КС -г зузсоіог 

Ключ -г указывает компилятору ресурсов, что соз- 
данный файл 8У8СОШК.КЕ8 не надо вписывать в ис- 
полняемый файл ЗѴЗСОШК.ЕХЕ (это для нас сде- 
лает ТигЬо Разсаі). 

Если вы набрали файл ресурсов вручную, то, преж- 
де чем компилировать его, создайте пиктограмму. Для 
этого вызовите Редактор Ресурсов , входящий в состав 
пакета ТигЬо Разсаі для >Ѵіпбо>ѵз ОѴЬііедѵаіег Кезоигсе 
ТооІкИ, >ѴКТ), вызовите редактор пиктограмм и нари- 
суйте пиктограмму, подобную изображенной на рис. 1 . 
Нарисуйте три горизонтальные полосы — красную, 
зеленую и голубую, пересеченные изображением регу- 
лятора (или изобретите более оригинальную 
картинку). После этого сохраните пиктограмму в 
файле 8У8СОІХЖ.ІСО и скомпилируйте ресурсы. 

Вообще существует два способа создания ресурсов 
для программы под >Ѵігкклѵз: во-первых, можно с по- 
мощью обычного текстового редактора создать файл 
ресурсов вручную, а потом скомпилировать его при 
помощи программы КС.ЕХЕ, как это показано выше. 


Заметим, что для этого нужно знать язык описания 
ресурсов и, кроме того, вам придется вручную вводить 
координаты точек на экране. 

Гораздо удобнее сразу создавать файл *.КЕ8 при 
помощи >УКТ. Потом можно сохранить созданные ре- 
сурсы в файле *.КС для документации. Именно так 
были созданы ресурсы программы 8узСо1ог. 

После создания ресурсов вызовите ТР^ и загрузите 
в него исходный текст программы 8узСо1ог — 8У8- 
СОІХЖ.РА8. Нажатием клавиш СІГІ-Р9 вы можете 
прямо в >Ѵіпсіо^ѵ5 скомпилировать и запустить про- 
грамму 8узСо1ог (компиляция без запуска про- 
граммы — АИ-Р9)! Как ТигЬо Разсаі для 008, ТигЬо 
Разсаі для >Ѵіпбо\ѵз за один прием скомпилирует про- 
грамму и создаст исполняемый модуль. 

Программу для АѴіпбо^ѵз можно создать также и из 
командной строки при помощи следующей команды: 

ТРС\Ѵ зузсоіог 

Отметим, что если при компиляции программы в 
среде М8-ООБ ограничение оперативной памяти в 
640 Кбайт иногда бывает существенным, то компиля- 
тор ТР^ использует всю оперативную память ПЭВМ, 
поскольку является настоящим приложением ^іпбо\ѵз 
(а не запускает дочерний процесс М8-Э08, как можно 
ошибочно подумать). Поэтому, если на вашем ком- 
пьютере установлена, например, расширенная память 
объемом 1 Мбайт, то вы можете создавать действи- 
тельно гигантские программные проекты. 

После того как программа 8узСо1ог будет создана, 
скопируйте ее в каталог \Ѵіпс1олѵз. Вызовите РПе Мап- 
а^ег и мышью “перетащите" файл 8У8СОШК.ЕХЕ в 
окно любой группы. Тем самым вы добавите к сред- 
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ствам >Ѵіп<1о^ѵ5 еще одно (на этот раз свое собствен- 
ное!). 

Как работает программа ЗузСоІог 

На рис. 2 показано окно программы ЗузСоІог. Три 
полосы прокрутки слева вверху позволяют пользова- 
телю изменять красную, зеленую и голубую компо- 
ненты цвета, отображаемого в большом прямоуголь- 
нике с подписью Соіог в центре окна: 


Рис. 2. Окно программы ЗузСоІог 

При помощи кнопок управления полосами про- 
крутки вы можете изменять соотношения цветовых 
компонент, выбирая тем самым один из более чем 
16 миллионов цветов. Большинство цветовых оттенков 
>Ѵіпдодѵз изображает штриховкой, поскольку ни один 



БувСоІог - Зеі еузіет соіогв 

1 МіНеп іп ТигЬо РазсаІ Іог ѴѴіпсіоѵ/з 



Рис. 3. Окно “АЬоиІ ЗузСоІог ...“ 


персональный компьютер не может отображать на 
дисплее такое количество цветов одновременно. 

Поработав с программой ЗузСоІог, вы заметите, что 
она управляется только мышью. Без мыши вы можете 
вызвать программу и работать с меню, однако 
изменить системные цвета не можете. Конечно, 
программу можно усовершенствовать так, чтобы она 
поддерживала одновременно и работу с клавиатурой, 
но в данном варианте в целях простоты этого не 
предусмотрено. 

Для того чтобы изменить 
системный цвет, укажите курсором 
мыши на одну из цветовых полос 
справа и нажмите на левую кнопку 
мыши. Не отпуская ее, переместите 
курсор на то поле, куда вы хотите 
скопировать этот цвет, и отпустите 
левую кнопку (если вы отпустите 
кнопку в поле окна вне цветовых 
полос, то копирование будет отме- 
нено). Цвета можно копировать из 
одной системной области в другую 
или из большого цветового поля в 
центре окна (цвет которого можно 
установить с помощью полос про- 
крутки). 

Меню программы ЗузСоІог очень 
простое и содержит всего две ко- 
манды: команду “АЬоиІ ЗузСоІог... “, 
которая отображает окно описания 
программы, и команду “ЕхіГ 4 , позво- 
ляющую завершить работу про- 
граммы. 

Диалоговое окно, вызываемое командой “АЬоиІ Зуз- 
СоІог../ 4 , — стандартный объект ^іпсіоаѵз. Для его 
поддержки нужно минимальное количество операторов 
ТР>Ѵ (см. рис. 3 и процедуру ЗОѴіпсІодѵ.СМАЬоиІ в 
листинге программы). 

После изменения одного или нескольких цветов 
можно внести сделанные изменения в АѴіпдоѵѵз, для 
чего нужно “нажать 44 мышью на кнопку Зеі. Для тех 
системных областей, где можно использовать только 
чистые цвета, >Ѵіпс1одѵз будет заменять комбинирован- 
ные цвета на ближайшие чистые. 

Выбранную вами настройку системных цветов 
можно сохранить в файле системных цветов >ѴіпсІо^ѵ 5 
5ѴЗСОШК..ШІ. Для этого нужно “нажать 44 кнопку 
Заѵе. Программа ЗузСоІог создаст этот файл в ката- 
логе >ѴіпсІо>ѵ5. Если вы изменили системные цвета, но 
не сохранили их, при следующем запуске ЗузСоІог па- 
литра системных цветов не будет соответствовать те- 
кущей. В этом случае можно сбросить неверную па- 
литру кнопкой Кезеі. 

Автоматическая загрузка палитры 

Сохранив выбранную настройку в файле 5Ѵ5- 
СОІХЖ.ІЫІ, вы можете настроить программу ЗузСоІог 
таким образом, чтобы она при вызове загружала цвета 


Мели 





Соіог 


Зсгоіі Ваг 
Вескдгоипд 
Асііѵе Сарііоп 
ІласЙѵе Сарйоп 
Мели 
ѴѴІпгіо* 

ѴѴІпгіоѵ* Ггагле 
Мели Тех! 
Ѵ/іп(іо*г Техі 
Саргіол Тех! 
Асііѵе Воггіег 
ІласМѵе Воггіег 
Арр ѴѴогк Зрасе 
НідЫідМ 
НідЫідМ Тех! 
ВиКол Расе 
ВиПол ЗНагіо* 
Сгау Тех! 
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ОБЪЕКТНО-ОРИЕНТИРОВАННОЕ ПРОГРАММИРОВАНИЕ В СРЕДЕ ТШВО РА5САЕ ДЛЯ >ѴШОО\Ѵ$ 


автоматически. Для этого при помощи текстового ре- 
дактора добавьте в файл 5Ѵ8СОЬ(Ж.ШІ строку 

попзіор = Ігие 

После этого при следующем запуске ЗузСоІог про- 
грамма автоматически загрузит цвета из файла 8ѴЗ- 
СОІХЖ.ІЫІ и “нажмет 44 кнопки 8еІ и (}иіІ. Запустить 
программу ЗузСоІог в автоматическом режиме можно 
также из командной строки при помощи ключа -п: 

5Ѵ5СОШК -п 

Если вы установили автоматический режим в файле 
8Ѵ8СОІХЖ.ІЫІ, то отключить его можно, либо удалив 
строку попзіор = Ігие, либо заменив ее на строку поп- 
зіор = Гаізе. Можно также запустить программу с клю- 
чом -з, который отключает автоматический режим 
даже в том случае, если он установлен в файле 5Ѵ5- 
СОШК.ІЫІ. Удобнее всего задать для программы 8уз- 
Соіог постоянную командную строку С КЛЮЧОМ -5 при 
помощи команды РПе | Ргорегііез утилиты Рііе Мап- 
а^ег. Для того чтобы утилита 8узСо1ог автоматически 
загружалась и устанавливала цвета при запуске Ѵ/Чп- 
(Іоѵѵз, следует добавить команду КГІЫ в файл АѴШ.ШІ: 

гип = С:\\ѴІЫОО\Ѵ8\зузсо1ог.ехе 

При этом, вызывая программу 8узСо1ог, можно бу- 
дет менять текущие настройки, с тем чтобы они 
использовались при следующем запуске Ѵ^іпсіоаѵз. 

Обратите внимание, что программа 8узСо1ог позво- 
ляет устанавливать цвета лучше, чем стандартная 
утилита Соіог. Так, с ее помощью вы можете устано- 
вить цвет выделения выбранного пункта меню как 
черный на фоне морской волны: 

НівЫіяЫ = ЕСВ (0, 2 55, 255) 

Ні^Ыі^Ні Тех! = КСВ (0, 255, 255) 

Как работает программа ЗузСоІог 

Знакомство с исходным текстом программы 8уз- 
Соіог лучше всего начинать с ее конца, где вы можете 
увидеть следующие строки: 

ѵаг 

8САрр: 8САрр1ісаІіоп; 

Ье$іп 

8САрр.Іпіі (арр Кате); 

8САрр.Кип; 

8САрр.Оопе 

епсі. 

Если вы знакомы с ТигЬоѴізіоп — объектно-ориен- 
тированным окружением для программирования на 
языке ТигЬо Разсаі под М8-Э08 — то легко узнаете 
эти операторы. Все они встречаются в программах на 
ТигЬоѴізіоп точно в таком же виде (за исключением 
параметра функции ЗСАрр.ІпіІ, который указывает 
имя программы). Однако не следует делать вывод о 
том, что ТигЬоѴізіоп и библиотека ОЬіесІ\ѴіпсІо>ѵ5 
ТР\Ѵ совместимы друг с другом. Нет, они не совме- 
стимы, хотя идеология 0 Ь]есІ\ѴіпсІ 0 Аѵз во многом 


сходна с ТигЬоѴізіоп и имена многих объектов этих 
библиотек совпадают друг с другом. Для того чтобы 
перенести программу ТигЬоѴізіоп в О^есМЧпсІомѵз, 
придется проделать довольно значительную работу. И, 
тем не менее, если вы знакомы с ТигЬоѴізіоп, вам 
значительно легче будет освоить О^есІ^іпсІодѵз. 

Как и в ТигЬоѴізіоп, большинство программ, 
использующих окружение ОЬ]есІ>ѴіпсІо^з, начинаются 
с описания объекта, принадлежащего классу ТАррІіса- 
Ііоп — самому старшему классу в иерархии объектов 
ОЬіесІ\Ѵіпс1о>ѵз. Для большинства программ этот про- 
изводный класс весьма прост. В нем определяются 
только два метода — Іпіі и ІпііМаіпАѴіп<Іо^ѵ, замеща- 
ющие конструкторы родительского класса. В про- 
грамме ЗузСоІог создание нового класса выглядит так: 
іур° 

5САрр1ісаІіоп = ОЬ}есІ (ТАррІісаІіоп) 
сопзігисіог Іпіі (АШте: РСЬаг); 
ргосесіиге ІпііМаіпЛѴіпскт; ѵіпиаі; 
епсі; 

{другие определения} 
епсі; 

Конструктор ЗСАррІісаІіоп.ІпіІ определяется ниже: 

сопзіпісіог 8САрр1ісаІіоп.ІпіІ(А№те: РСЬаг); 

Ье^іп 

ТАррІісаІіоп. Іпіі (АЫате); 

ІпііЗузСоІогАггау; {Инициализация цветов} 

Ьоас13еиіп$$; {Загрузка настроек из файла *.ШІ} 
Сеі8\ѵіІсЬе$; {Обработка аргументов командной строки} 
іі попЗіор іЬеп Ье^іп 

СЬап^еЗузСетСоІоге; {Установка системных цветов} 
Ро$1(}иііМе$$а8е(0); {Выход без отображения окна} 
епсі; 
епсі; 

В этом конструкторе первый оператор ТАррІіса- 
Ііоп. Іпіі (АЫате) вызывает стандартный метод Іпіі 
объекта родительского типа (ТАррІісаІіоп). В нем ре- 
ализована стандартная последовательность инициали- 
зации окна приложения для >Ѵіп<клѵз. Затем в кон- 
структоре 8САрр1ісаІіоп.ІпіІ определяются функции 
объекта ЗСАррИсаІіоп, отсутствующие в объекте роди- 
тельского типа ТАррІісаІіоп: инициализация цветов, 
загрузка настроек из файла *.ШІ, обработка аргумен- 
тов командной строки и пр. 

Оператор ТАррІісаІіоп. Іпіі инициализирует главное 
окно приложения посредством вызова метода Іпіі- 
Маіп\Ѵіп<1олѵ. Этот метод является виртуальным, т.е. 
каждый тип-наследник родительского типа ТАррІіса- 
Ііоп может (а для данного метода даже должен) пере- 
определять его для инициализации объекта дочернего 
типа (в нашем случае типа ЗСАррІісаІіоп). 

Если бы метод ІпііМаіп\Ѵіпс1о>ѵ не был переопреде- 
лен, то при инициализации окна был бы использован 
метод родительского класса Т\Ѵіпс1о>ѵ.ІпііМаіп\Ѵіпс1о^, 
который бы создавал, естественно, окно типа ТМпсіо>ѵ 
(простейшее пустое окно), а не типа 8С\Ѵіпсіо\ѵ. 

Переопределение метода ІпііМаіп>Ѵіпс1о>ѵ в нашем 
случае выглядит так: 
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ргосесіиге ЗСАррІісаііопЛпііМаіп^Ѵіпсіош; 

Ье^іп 

Маіп\ѴіпсІо>ѵ : = 

Кеѵѵ (Р$ОѴіпсіо\ѵ, Іпіі (піі, '5е< Зузіет Соіогз')); 

епсі; 

Функция №\ѵ резервирует свободное место в гло- 
бальном хипе для окна — объекта типа 8С>Ѵіпс1о>ѵ, со- 
здаваемого конструктором этого типа БСѴѴіпскпѵ.ІпіІ. 
Поскольку это окно не принадлежит никакому окну 
данного приложения, первым параметром, передава- 
емым конструктору 5С>Уіпс1оаѵ.іпН, является піі. Если 
бы создавалось дочернее окно, принадлежащее дру- 
гому (родительскому) окну, то первым параметром 
вместо нуля следовало бы передавать адрес родитель- 
ского объекта (обычно хранящийся в параметре 8еЮ. 
Вторым параметром передается текстовая строка, ко- 
торая будет отображена в заголовке окна. 

Если вы посмотрите на описание типа ЗОѴіпсІодѵ, 
то обнаружите, что это сложный объект. Именно здесь 
определены почти все переменные, процедуры и функ- 
ции программы БузСоІог. Для облегчения восприятия 
этого объекта, его описание в исходном тексте разде- 
лено на три части: данные, замещаемые методы роди- 
тельского класса и новые методы. Пока, наверное, не 
следует углубляться в изучение этого объекта. Предпо- 
ложим, что окно создано и процедура БСАрр.ІпіІ за- 
вершила свою работу. Что происходит дальше? 

Возвращаясь к основной программе из трех строк, 
можно увидеть, что после инициализации приложения 
вызывается функция ЗСАрр.Кип. Те из вас, кто уже 
программировал для ХѴіпсІо^ѵз, могут высказать пред- 
положение, что именно здесь находится цикл обра- 
ботки сообщений (Мезза^е Ьоор). Однако, как это ни 
странно, программы на ОЬцесіХѴіпсІоѵѵз не имеют цикла 
обработки сообщений. Более того, нигде в программе 
ЗузСоІог вы не найдете ничего похожего на обычные 
механизмы диспетчеризации сообщений ХѴіпсіоаѵз, так 
хорошо знакомые программистам на С! Как же тогда 
программа обрабатывает события? Для того чтобы это 
понять, необходимо разобраться с новой для системы 
ТигЬо Разсаі особенностью — использованием Дина- 
мических Методов (Оупатіс МеІЬосіз). 

Динамические методы и обработка событий 

Операционная оболочка МісгозоН >Ѵіпсіоаѵз является 
средой, управляемой событиями. События (перемеще- 
ния мыши, нажатия ее кнопок и клавиш на 
клавиатуре и пр.) обрабатываются оболочкой \Ѵіпс1одѵз 
и переводятся в системные сообщения, которые поме- 
щаются сначала в системную очередь сообщений, а 
потом направляются в очередь приложения, которому 
это сообщение предназначено (или, в отдельных слу- 
чаях, всем приложениям). Так, например, когда вы 
нажимаете левую клавишу мыши, >Ѵіпбо^ѵз посылает 
приложению сообщение, кодируемое константой 
дѵш__МоизеМоѵе. 

Те из вас, кто программирует на С, узнали знако- 
мое сообщение, которое на С выглядит как 


>ѴМ_М01І8ЕМ0ѴЕ. Конечно, имена всех системных 
констант и флагов, используемых в ТР^, совпадают с 
определенными в 5ЭК. Однако в Разсаі не принято 
вводить константы большими буквами (а имена сооб- 
щений являются в ТР>Ѵ константами), и поэтому 
имена сообщений не печатаются большими буквами, 
как в 8ЭК. Поскольку Разсаі, в отличие от С и С++, 
не различает большие и малые буквы, на совмести- 
мость с 8ЭК это небольшое изменение не влияет. 
Зная, что константы в ТР\Ѵ начинаются всегда с ма- 
лой буквы, вы никогда не спутаете константу с про- 
цедурой или функцией (а также с объектом или 
указателем, имена которых начинаются с букв “Т и и 
“Р“ соответственно). Если вы будете пользоваться 
этими несложными общепринятыми соглашениями, вы 
повысите читабельность своих программ и сможете 
легче разобраться в чужих. 

Что же происходит с сообщением, которое ЛѴі псіолѵз 
посылает приложению? В обычном (не объектно-ори- 
ентированном) программировании программа сама 
извлекает сообщение из очереди приложения и пере- 
дает соответствующей подпрограмме. Программируя 
на ТР\Ѵ, вы избавлены от необходимости писать код 
на таком низком уровне (хотя в принципе это воз- 
можно). ОЬіесІ\Ѵіпс1о^ берет на себя всю обработку 
сообщений. Обычно этого бывает достаточно для 
большинства применений. 

Для обработки сообщений в ОЬцесіХѴіпсІо^ѵз имеются 
специальные методы. Для каждого сообщения суще- 
ствует свой метод. По приходе сообщения в очередь 
приложения >Ѵіпс1о>ѵзОЬ]есІ вызывает для его обра- 
ботки соответствующий метод. При таком способе 
обработки сообщений объекты приложения реагируют 
на сообщения независимо друг от друга (возможно, 
даже одновременно). 

В определении типа 5С\Ѵіпс1о>ѵ, наследника типа 
ТЛѴіпсІо^, метод-обработчик, например, сообщения 
шшМоизеМоѵе может быть определен следующим 
образом: 

ЗОѴіпсІош = ОЪіесІ (Т\Ѵіпс1о>ѵ) 

ргосесіиге \ѴММоизеМоѵе (ѵаг Мз^: ТМезза^е) ; 
ѵіпиаі ѵѵга РігзІ + ѵѵт_МоизеМоѵе; 

епсі; 

При вызове метода ^УММоизеМоѵе в параметр 
Мз§ помещается указатель на запись стандартного 
типа ТМе$за§е, содержащую всю информацию сооб- 
щения. Так, в случае сообщения ^ѵт_МоизеМоѵе че- 
рез параметр Мз§ в определении метода доступны ко- 
ординаты X и V нового положения мыши. 

Имя метода ^VММои5еМоѵе отвечает принятому со- 
глашению об именах методов обработки сообщений. 
По этому имени ясно, что метод обрабатывает сооб- 
щение >Ѵіп<клѵз (>Ѵіпс1о>ѵ5 Мезза^е, \ѴМ) 
дѵш МоизеМоѵе. Однако вы можете назвать метод 
обработки этого сообщения и по-другому — не имя 
метода определяет тип обрабатываемого сообщения. 
Как же ОЬ]ес1\ѴіпсІо>ѵ5 определяет, какой метод вы- 
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звать при приходе сообщения \ѵш_МоизеМоѵе в оче- 
редь приложения? 

В ОЬіесОѴіінІотѵз эта диспетчеризация осуществля- 
ется при помощи механизма так называемых 
динамических методов. Каждому методу обработки 
сообщения ставится в соответствие уникальный индекс 
в специальной таблице. В приложении, переопределяя 
методы обработки сообщений, программист также 
присваивает каждому методу свой индекс. Так, в 
примере выше в строке, начинающейся с оператора 
ѵігіиаі, индекс метода ^ММоизеМоѵе определяется 
как \ѵт_Ріг$1 + *т_Мои$еМоѵе. При этом константа 
>ѵтп__Ріг$1 определяет стандартный индекс начала таб- 
лицы динамических методов всех оконных сообщений 
>Ѵіпскпѵз, а константа \ѵтп_Мои$еМоѵе — смещение в 
этой таблице, по которому осуществляется передача 
управления по приходе сообщения ^тп^МоизеМоѵе. 
Аналогично константа сітИРігзі используется для уста- 
новки индекса метода на начало таблицы методов — 
обработчиков командных сообщений (сообщений, при- 
ходящих при выборе команд меню). При этом опреде- 
ление метода обработки командных сообщений отли- 
чается от определения метода обработки оконных со- 
общений только индексом таблицы динамических ме- 
тодов. Вот, например, как выглядит в программе 
БузСоІог определение метода обработки команды 
“АЬоиІ ЗузСоІог ...“ меню программы: 

ЗС\Ѵіпсіо\ѵ = ОЬ]есІ (Т\Ѵіпс1о\ѵ) 

ргосесіиге СМАЪоиІ (ѵаг Мз^: ТМезза^е) ; 
ѵігйіаі сш_Рігз( + сш АЬоиГ, 

епгі; 

Значение константы ст_АЪоиІ здесь то же, что и в 
определении меню программы ЗузСоІог в файле ресур- 
сов. 

Эта константа прибавляется к константе ст_Ріг$1 и 
используется в качестве индекса для доступа к методу 
через таблицу динамических методов. Этим одно- 
значно определяется, что при выборе пункта “АЪоиІ 
8узСо1ог ..." меню ЗузСоІог будет вызвана функция 
СМАЪоиІ. Отметим, что, поскольку выражения, опре- 
деляющие индексы, являются константами, они вы- 
числяются на этапе компиляции и не замедляют ра- 
боту программы. 

Комбинирование обычного 
и объектного программирования 

Программа на ТР>Ѵ не обязана быть полностью 
“объектно-ориентирован ной“. Как показывают первые 
шесть процедур программы 8узСо1ог, вы можете при- 
менять смешанное — объектно-ориентированное и 
традиционное программирование. Из исходных текстов 
видно также, что вы можете в любое время вызывать 
различные функции АѴігкіолѵз для выполнения тех или 
иных операций. Таким образом, нет никакой необхо- 
димости оформлять каждую операцию АѴіпбо^ѵз в виде 
объекта. 


Например, для того чтобы загрузить в массив про- 
граммы набор системных цветов, процедура ІпіІЗуз- 
СоІогАггау непосредственно вызывает функцию Сеі- 
ЗузСоІог библиотеки ЖЧпРгосз, а процедура 
СЬап§е§у$1етСо1ог$ аналогичным образом вызывает 
функцию ЗеіЗузСоІогз. Справочное руководство по 
ТР>Ѵ подробно описывает эти и другие функции 
АѴіпбодѵз, которыми можно пользоваться в программах 
на ТРАѴ; общее число их достигает 600 (!). 

Просматривая исходный текст 8узСо1ог, программи- 
сты на ТигЪо Разсаі для М8-008 сразу обратят вни- 
мание на несколько необычных для Разсаі конструк- 
ций, служащих для обеспечения совместимости про- 
грамм на Разсаі с системой, написанной на С, каковой 
является МісгозоН >Ѵіпс1о>ѵз. Первое, что бросается в 
глаза, — это новые функции обработки строк, кото- 
рые в С должны оканчиваться нулями. В ТигЪо Разсаі 
для >Ѵіпс1оаѵ5 включена специальная библиотека 
31гіп§5, которая содержит процедуры и функции для 
копирования, сравнения и выполнения других стан- 
дартных операций над такими строками, а также 
преобразования строк из формата Разсаі в формат С и 
обратно. Одна из таких процедур — ЗІгРСору вызы- 
вается в функции Іп(2$(г программы ЗузСоІог. Она 
переводит строку Разсаі “8“ в оканчивающуюся нулем 
строку формата С, указатель на которую помещает в 
переменную “С“ типа РСЬаг. 

Тип РСЬаг — это также нововведение для Разсаі. 
Переменная типа РСЬаг является указателем на мас- 
сив символов, оканчивающийся нулем. Первый эле- 
мент такого массива имеет индекс 0 (а не 1, как это 
принято в Разсаі). Таким образом, переменная типа 
РСЬаг является указателем на символьную строку, 
принятую в языке С и используемую в функциях Мі- 
сгозоН \Ѵіпбошз. Если вызываемая функция ^іпбодѵз 
требует, чтобы аргумент был дальним указателем на 
строку символов (ЬР8ТК в МісгозоН 8ЭК, что соответ- 
ствует типу сЬаг Гаг * языка С), то передаваемая 
строка должна быть приведена к типу РСЬаг, напри- 
мер: 

Апг.Мепи := ЬоасІМепи (НІпзІапсе, РСЬаг (і(і_Мепи)); 

Наиболее проницательные из вас непременно заме- 
тят, что в приведенном выше примере параметр 
і(3_Мепи не является строкой — это целочисленная 
константа, определяющая индекс меню. Как же в этом 
случае работает преобразование типа 

РСЬаг (і<І_Мепи), и вообще, что происходит при пере- 
даче такого параметра функции ЬоабМепи системы 
>Ѵіп(1о>ѵз? Результат этого преобразования можно 
представить таким образом: 


Переменная 

Эес 

Нех 

іЦМегш 

100 

$0064 

РСЬаг (Ш_Мепи) 

- 

$0000:0064 


Как видим, функции ЬоабМепи на самом деле вер- 
ный указатель не передается (строка приложения 
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пользователя не может храниться в нулевом сегменте), 
а идентификатор меню записывается в смещении пе- 
редаваемого фиктивного адреса. 

Этот трюк связан с необычной возможностью, кото- 
рой обладают некоторые функции >Ѵіпс1о\ѵ5. Если 
функции ДѴіпбоѵ/з требуется передать идентификатор 
ресурса (“гезоигсе Ш“), всегда имеющий тип РСЬаг 
(ЬРЗТК. в ЗЭК), то вы можете передать ей как имя 
идентификатора ресурса (текстовую строку), так и 
сам идентификатор (целое число). Если в сегментной 
части адреса находится не ноль, то считается, что пе- 
редается адрес текстовой строки; если в сегментной 
части ноль (фиктивный адрес), то функция извлекает 
из смещения непосредственно сам идентификатор. 
Второй вариант намного короче, поскольку при этом 
нет необходимости извлекать идентификатор из таб- 
лицы ресурсов. 

Возможно, программисту на Разсаі эти ухищрения 
покажутся чрезмерными, но, как известно, в чужой 
монастырь со своим уставом не ходят: программируя 
для системы АѴіпсІоіѵз, написанной на С, приходится 
придерживаться соглашений и стиля программирова- 
ния языка С. Переписать же библиотеку >Ѵіп(Іоіѵз на 
язык Разсаі невозможно: дело в том, что библиотека 
>Ѵіп<кяѵз — это часть операционной оболочки (вызовы 
функций АѴіпсІото отрабатываются самой АѴіпбоіѵз). 
Так что программистам на Разсаі, по-видимому, при- 
дется смириться со странными с точки зрения Разсаі 
конструкциями типа РСНаг (іб_Мепи). 

Интерфейс с графическими устройствами 

Ни одна статья о программировании в >Ѵіпс1ош5 не 
может быть полной без упоминания об интерфейсе с 
графическими устройствами (СгарЬісз Оеѵісе ІпіегГасе, 
СОІ) — богатой библиотеке структур данных, фун- 
кций и процедур, обеспечивающих графический вывод 
на т.н. виртуальное графическое устройство. Для лю- 
бителей графики эта библиотека делает программиро- 
вание в >ѴіпсІо\ѵз особенно привлекательным. Вместо 
того чтобы создавать несколько вариантов одной и той 
же программы для совместимости с различными ти- 
пами устройств, вы можете написать одну-единствен- 
ную программу, которая при помощи будет га- 
рантированно осуществлять графический вывод на все 
графические устройства — от принтеров и плоттеров 
до мониторов высокого разрешения. Вообще, если вы 
используете СОІ, то ваша программа сможет работать 
нД любом устройстве, которое поддерживает СОІ. 

В программе ЗузСоІог используется несколько фун- 
кций СОІ, но это только крохотная часть колоссаль- 
ного набора графических процедур. Большинство фун- 
кций очень просты. Посмотрите, например, на про- 
цедуру Ога^КиЬЬегВапб, рисующую “резиновую ли- 
нию 4 *, которую можно видеть при копировании цветов. 
В этой и других графических функциях вы увидите 
параметр ЭС или РаіпЮС. Эти параметры опреде- 
ляют структуру АУіпсІото, которая называется также 
контекстом отображения (бізріау сопіехі). Это до- 


вольно сложное понятие СОІ, включающее в себя 
описание физических свойств конкретного устройства 
и, кроме того, использующееся для разделения рабо- 
чих областей различных приложений \Ѵіпсіодѵ5. 

В многооконной операционной оболочке, какой яв- 
ляется >ѴіпсІо>ѵ5, экран монитора — разделяемый ре- 
сурс, т.е. он может использоваться одновременно мно- 
гими приложениями. В каждый конкретный момент 
времени приложение АѴіпсІошз 44 не знает 44 , какую 
область экрана оно занимает. Поэтому очевидно, что 
графический вывод в ХѴіпскпѵз не может осущест- 
вляться непосредственно на экран (например, путем 
записи в видеопамять) — эту функцию выполняет 
операционная оболочка, работающая с контекстами 
отображения различных приложений. 

Органы управления и дочерние окна 

У объекта класса ЗОѴіпбош, наследника класса 
ТЛѴіпбо^ѵ, в свою очередь, есть дочерние объекты 
(окна). Одним из таких дочерних объектов является, 
например, полоса прокрутки для изменения веса крас- 
ного цвета. Кнопка 8еІ также является дочерним объ- 
ектом главного окна программы ЗузСоІог. Такие до- 
черние окна называются органами управления. 

Как это известно всем пользователям АѴіпбоѵз, 
органы управления обычно располагаются в специаль- 
ных диалоговых окнах. Но, как показывает пример 
программы ЗузСоІог, органы управления можно также 
разместить непосредственно на поле главного (или 
любого другого) окна приложения >Ѵіпсіош5. 

В ЗузСоІог обращение к трем цветовым полосам 
прокрутки осуществляется посредством указателей: 

ЗВагКегі, ЗВагСгп, ЗВагВІи : РЗсгоНВаг; 

При помощи этих указателей можно обращаться к 
объектам типа ТЗсгоІІВаг — одного из нескольких 
стандартных типов объектов — органов управления, 
определенных в ОЬцесЛѴіпскпѵз. К другим стандартным 
органам управления относятся, например, ТВиІІоп 
(кнопка), ТСІіескВох (кнопка 44 Вкл/Выкл 44 ), ТКа- 
біоВиПоп (кнопка-переключатель) и другие. То, что 
эти и другие органы управления оформлены в виде 
объектов, значительно упрощает работу с ними. 

Для того чтобы к органам управления можно было 
обращаться, их адреса помещаются в локальных пере- 
менных (ЗВагКеб). Сами объекты создаются всего 
лишь одним оператором: 

ЗВагКесІ : = (РЗсгоНВаг, 

ІпИ(@5е1Г, і(1_8ВагКе<І, 50, 20, 250, 0, !ше)); 

Конструктор инициализирует объект и вызывает 
процедуры Шіпбо^ѵз, которые создают соответству- 
ющие структуры данных этого органа управления. Ар- 
гумент @5е1Г передает адрес текущего объекта 
ЗОѴіпсіочѵ как адрес родительского объекта (на 
‘‘языке 44 >Ѵтёо^ѵ5 дочерний объект принадлежит роди- 
тельскому). Другие аргументы определяют сообщение, 
которое генерирует орган управления (іб^ЗВагКеб), 


3 ЗахЛ419 
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координаты органа управления в окне приложения и 
горизонтальную ориентацию полосы прокрутки Ігие 
(если бы передавался аргумент Таізе, то полоса про- 
крутки была бы ориентирована вертикально). 

Для того чтобы обрабатывать события полосы про- 
крутки, в классе ЗС\Ѵіп<іо\ѵ объявляется специальный 
метод обработки сообщения М_8ВагКес1. Объявление 
этого метода весьма похоже на объявление методов 
обработки других сообщений; отличается только 
индекс динамического метода: 

ргосегіиге ЗВагКесІЕѵепі (ѵаг Мз^: ТМезза^е) ; 
ѵігйіаі ігіРіге! + і(1_5ВагКес1; 

Подобно индексам \ѵт_Ріг5І и ст_Ріг$1 константа 
і<і_Ріг$1 определяет начальное значение индекса таб- 
лицы динамических методов органов управления. 
Сумма Ш_Ріг5І + і<1_$ВагКесІ определяет уникальный 
индекс, который О^есіМ^іпбоАѵ использует для вызова 
метода по получении сообщения і<І_8ВагКес1. В ре- 
зультате, когда происходит какое-либо событие с по- 
лосой прокрутки, метод ЗВагКесІЕѵепІ работает так, 
как если бы он был физически соединен со “своим 44 
органом управления. Обрабатывая событие, метод мо- 
жет извлекать информацию об органе управления из 
сообщения М$§. Например, для того чтобы извлечь 
значение, на которое в данный момент времени уста- 
новлен регулятор полосы прокрутки, в методе 
ЗВагКесІЕѵепІ используется следующий оператор: 

КесІСоІог : = ЗВагКесГ.СеіРозіііоп; 

Другие органы управления и поддерживающие их 
методы создаются и обрабатываются аналогично. Как 
можно убедиться из листинга программы ЗузСоІог, 
большая часть кода, реализующего функции про- 
граммы ЗузСоІог, приходится на долю именно методов 
поддержки дочерних органов управления — типичная 
ситуация для программы на ДУіпсІснѵз. 


Подведем итоги 

Программа ЗузСоІог дает начальное представление 
о том, как можно писать программы в среде ОЬ- 
Іес1>Ѵіп(і<жз. Я работаю с ТР\Ѵ уже год и получил ни с 
чем не сравнимое удовольствие наблюдать за тем, как 
компилятор рос от нескольких простых тестовых фай- 
лов до полномасштабного средства разработки про- 
грамм для АѴіпсіслѵз, серьезно претендующего на ли- 
дерство в этой области. Программа ЗузСоІог была 
одной из моих ранних попыток написать полное при- 
ложение для ^іпсіо^з. Поскольку среда была для меня 
сравнительно новая, создание программы заняло 
больше времени, чем можно было предполагать. И, 
тем не менее, легкость, с которой я осваивал техноло- 
гию ОЬ]ес1\Ѵіпс1о\ѵ5, произвела на меня довольно силь- 
ное впечатление. 

И все же я не утверждаю, что программировать на 
ТР\Ѵ с использованием окружения ОЬ]ес1\ѴіпсІоѵѵ5 про- 
сто. Создание приложений для ХѴіпсІоѵѵз — сложная 
задача, вне зависимости от того, с какой системой 
программирования вы работаете. Однако по проше- 
ствии нескольких месяцев использования ТР^ и ОЪ- 
]есМіп(1о^ѵ5 я не смог найти причины, которая заста- 
вила бы меня вернуться к 8ЭК и языку С. ТР^ пред- 
лагает свежий объектно-ориентированный подход к 
программированию для ХѴігкІодѵз, и для меня нет до- 
роги назад. 

Т.Сван 

По материалам: 

Вогіапсі Ьапвиа^е Ехргезз, 1991, Ѵоі., N№2 
Статью перевел и переработал С. Гладков 


{ 5Ѵ5СОЮК.РА5 — Зеі Зузіет Соіоге (с) 1991 Ьу Тот Зто&п.} 
{$К 5Ѵ5СОШК.КЕ5} 

рго^гат ЗухСоІог, 

и$е$ \ѴіпТуре$, ѴѴіпРгосх, ѴѴОЬуесІв, Зігііцр; 


СОП5І 

арр пате = ’ЗухСоІог'; 
іпі_РТЯате * ЗУЗСОШКЛГЧГ; 
іс1_Мепи * 100; 
іс!_Ісоп = 200 ; 
ст_АЬоиІ * 101; 
ст Оиіі = 102; 
ісіЗВагК«І - 100; 
кі ЗВагОгп « 101; 
кі ЗВагВІи - 102; 
кі_5ТхіК«і - 103; 
кіЗТхіСгп - 104; 
кі_5ТхіВ1и = 105; 
ісі_$еіВіп * 106; 
ісі_Ке$еіВіп * 107; 
ісі_5аѵеВіп * 108; 
ісі_ОшіВіп = 109; 


{ Имя приложения } 

{ Имя файла настроек, Л1ЧІ } 

{ Идентификатор ресурса } 

{ Идентификатор пиктограммы } 

{ Идентификатор команды “АЬоиІ ...“ } 

{ Идентификатор команды “ЕхіІ“ } 

{ Идентификаторы органов управления } 


{ Маска извлечения значения цвета } 


{ Ключи: -в = отмена; -п = установка } 


КесІМаяк = 5000000РР; 

СгаМаак * ЗООООРРОО; 

В1иМа$к = ЯЮРРОООО; 

попЗіор: Вооіеап - (аізе; 

ЗувСоІогИате: Ахгау(0..со1ог_ЕпсіСо1ог$] оі РСЬаг = ( 
'Зсгоіі Ваг', 

'Васк&гоипсГ, 


Асігѵе Сарііоп', 

Іпасііѵе Сарііоп', 

'Мепи', 

’ѴѴіпсіоѴ, 

'ѴѴіпсіош Ргате', 

Мепи Тех!', 

'ѴѴіпсіоѵ ТехГ, 

'Сарііоп ТехІ', 

'Асііѵе Вогсіег', 

Іпасііѵе Вогсіег', 

'Арр \Ѵогк Зрасе , 

'Ні^Ыі^ЬГ, 

Ні&Ыі&Ы Тех!', 

'Виііоп Расе', 

'Виііоп ЗЬасіош', 

'Сгау ТехГ, 

'Виііоп Техі' 

); 

Іуре 

ЗСАррІісаІіоп = ОЬ)есІ(ТАрр1ісаІіоп) 
сопзігисіог Іпіі (А^ате: РСЬаг); 
ргосесіиге ІшіМаш\Ѵшс1а\ѵ; ѵігіиаі; 

епсі; 

РЗС^Іпсіоѵ = ^ЗСХѴіпсіоѵ; 

ЗСѴѴіпсІоѵ = ОЬ)есІ (ТѴѴтсіо'ш) 

{ Поля данных СЗЛѴіпсІоѵ } 

Ос : Нсіс; 

ВиПопОоѵп, СЬап^есі : Вооіеап; 

ЬіпеХІ, ЬіпеУІ, ІіпеХ2, 1дпеѴ2 : Іпіе^ег, 
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АггоѵСигхог, СгоххНаігСигхог : НСигхог, 

КесіСоІог, СгпСоІог, ВІиСоІог : Вуіе; 

ЗВагКесі, ЗВагСгп, ЗВагВІи : РЗсгоІІВаг, 

ЗТхіКесі, ЗТхіСгп, ЗТхіВІи : РЗіаІіс; 

ЗатрІеКесІ : ТКесІ; 

ЗатрІеСоІог : ТСоІогКеГ; 

Ога^вшвРп^ш : Іпіе^ег; 

{ Наследуемые С5\Ѵшс1о\ѵ методы } 

сопхігисіог Іпіі (АРагепІ: РѴѴіпсіоѵхО^есІ; АТіІІе: РСЬаг); 

Гипсііоп СапСІохе: Вооіеап; ѵігіиаі; 

ргосесіиге СеіѴѴіпсіоѵСІахх (ѵаг А\Ѵп<ЗС1ахх: ТѴѴпсіСІахх); ѵиіиаі; 

ргосесіиге ЗеІирѴѴіпсіслѵ; ѵиіиаі; 

ргосесіиге ѴѴМЬВиІІопОоѵп (ѵаг Мх^: ТМеххаде); 

ѵиіиаі \ѵт_Ри^1 +ѵѵт_ЬВииопІ)спѵп; 
ргосесіиге Раіпі (РаіпіС)С: НЕ)С; ѵаг РаіпІІпГо: ТРаіпіЗігисі); 
ѵиіиаі; 

{ Новые методы СЗѴѴіпсіоѵ } 

Гипсііоп ІпхісіеСоІогКесІ (X, V: Іпіедег; ѵаг ітіех: Іпіе^ег): Вооіеап; 

ргосесіиге КехеіЗухІетСоІогх; 

ргосесіиге ЗупсЬгопігеЗсгоІІВагх; 

ргосесіиге ОгаѵѵКиЬЬегВапсі; 

ргосесіиге СМАЬоиІ (ѵаг Мхд: ТМехха{$е); 

ѵиіиаі ст_Рігхі + ст_АЬоиІ; 
ргосесіиге СМОиіІ (ѵаг Мх{$: ТМехха^е); 

ѵігіиаі ст_РігхІ + ст_ОиіІ; 
ргосесіиге \ѴМІБиІІоп11р (ѵаг Мх# ТМехха^е); 

ѵігіиаі \ѵт_РігхІ + \ѵт_ІВиІІоп11р; 
ргосесіиге ѴѴММоихеМоѵе (ѵаг Мх$: ТМехха^е); 

ѵігіиаі ѵш_РігхІ+ѵт_МоихеМоѵе; 
ргосесіиге ЗВагКесІЕѵепІ (ѵаг Мх# ТМехха^е); 

ѵігіиаі іс1_РігхІ + ісі_5ВагКесі; 
ргосесіиге ЗВагСгпЕѵепІ (ѵаг Мх^: ТМехха^е); 

ѵігіиаі ісі_РігхІ + йі_5ВагСт; 
ргосесіиге ЗВагВІиЕѵепІ (ѵаг Мх$ ТМехха^е); 

ѵігіиаі ісі_РігхІ + ісі_5ВагВ1и; 
ргосесіиге ЗеіВіпЕѵепІ (ѵаг Мх$: ТМехха^е); 

ѵігіиаі іс1_РігхІ + ісі_5еіВіп; 
ргосесіиге КехеіВіпЕѵепІ (ѵаг Мх$: ТМехха^е); 

ѵігіиаі ісі_РігхІ + ісі_КехеіВіп; 
ргосесіиге ЗаѵеВіпЕѵепІ (ѵаг Мх{$: ТМехха^е); 

ѵігіиаі ісі_РігхІ + ісі_ЗаѵеВіп; 
ргосесіиге ОиііВіпЕѵепІ (ѵаг Мх$: ТМехха^е); 
ѵігіиаі ісі_РігхІ + іс1_ОиііВіп; 

епсі; 

ЗухСоІогКес = гесогсі 

Огі^іпаІСоІог : Ьоп&ІпІ; { Цвет при вызове программы } 

СиггепіСоІог ; Ьоп&іпі; { Новый установленный цвет } 

ЗСКесІ : ТКесІ; { Координаты цветового прямоугольника } 

епсі; 

іг 

ЗухСоІогАггау. Аггау [0..со1ог_Епс1Со1ог$] о( ЗухСоІогКес; 

{ Общие процедуры } 

{ Преобразование целого N в строковый массив С. 

Если Мах > 0, заполнить нулями. } 
ргосесіиге Іпі25іг (ІЧ, Мах; Іпіе^ег, С: РСЬаг); 
ѵаг 5: Зігіпв [6]; 

Ье^іп 

5іг (ГЧ, 3); 

\ѵЬі!е Ьеп^іЬ (5) < Мах сіо 3 : * '0* + 5; 

ЗігРСору (С, 8); 
епсі; 

{ Заполнить глобальный массив Зухсоіог текущими цветами } 

ргосесіиге ІпііЗухСоІогАггау; 

ѵаг 

і: Іпіе^ег; 

Ье&т 

Гог і : = 0 Іо со1ог_Епс1Со1огх сіо 
ѵііЬ ЗухСоІогАггау [і] сіо Ье^іп 
Оп^іпаІСоІог : = ОеіЗухСоІог (і); 

СиггепіСоІог : * Оп{рпа1Со1ог; 
ѵііЬ ЗСКесІ сіо Ье&т 
ЬеЛ := 500; 

Тор : = 20 + (і • 20); 

Кі&Ы : = ЬеЙ + 100; 

Воііот : = Тор + 15; 
епсі; 
епсі; 

епсі; 

{ Изменение системных цветов } 
ргосесіиге СЬап^еЗухІетСоІогх; 


ѵаг 

і: Іпіе^ег; 

ІпхАггау. Аггау [0..со1ог_Еп<ЗСо1огх] оГ Іпіе^ег; 

СІгАггау Аггау [0..со1ог_ЕпсіСо1огх] оГ ТСоІогКеГ; 

Ье^іп 

Гог і ; = 0 Іо со1ог_Епс1Со1огх сіо Ье&ш 
ІпхАггау(і] : = і; 

С1гАггау[і] ; = 5ухСо1огАггау(і].СиггепіСо1ог 
епсі; 

ЗеіЗухСоІогх (со1ог_ЕпёСо1огх + 1, ІпхАггау[0], СІгАггау); 
епсі; 

{ Сохранение цветов в файле 5Ѵ5СОЦОК.11ЧІ в каталоге ѴѴіпёоѵх } 

Гипсііоп ЗаѵеЗеІІіпях: Вооіеап; 
ѵаг 

і; Іпіе^ег; 

5: Зігіпв [12]; 

N^4^31 ие: Аггау [0..12] о( СЬаг; 

Ье^іп 

ЗаѵеЗеІІіп^х : = Ігие; 

!ог і : = 0 Іо со1ог_Епс1СоІогх сіо 
ѵііЬ ЗухСоІогАггау [і] сіо Ье^іп 
8іг(СиггепіСо1ог, 5); 

ЗігРСору (ИешѴаІие, 5); 

ІГ поі ѴѴгіІеРгіѵаІеРгоГіІеЗігіп^ (арр_Мате, 

ЗухСоЬгЫате [і], ЫеѵѴаІие, іпі_РТЧате) іЪеп Ье&іп 
ЗаѵеЗеІІіп^х : * Еаіхе; 

Ехіі 

епсі; 

епсі; 

епсі; 

{ Загрузка цветов из файла 5Ѵ5СОІХЖ.1ІЧІ (если есть) } 

ргосесіиге ЬоасіЗеІІіпцх; 

ѵаг 

і, Егп Іпіе^ег, 

5: Зігіпя [12]; 

ОеСаиІіѴаІие, ЫеѵѴаІие: Аггау [0..12] оГ СЬаг; 

Ье^ш 

Гог і : = 0 Іо со1ог_ЕпсіСо1огх сіо 
иііЬ 5ухСо1огАггау(і] сіо Ьерп 
5іг(СиггепіСо1ог, 5); 

ЗігРСору (ОеГаиІіѴаІие, 3); 

СеіРгіѵаІеРгойІеЗігіпк (арр_Nате, ЗухСоІогИате [і], 

ОеСаиІіѴаІие, ЫеѵѵѴаІие, хігеоі (ЫешѴаІие), іпі_РЫате); 

5 : = ЗігРах (ЫеѵѴаІие); 

Ѵаі (5, СиггепіСоІог, Егг); 

іГ Егг < > 0 іЬеп СиггепіСоІог : * Огі^іпаІСоІог; 
епсі; 

СеіРгіѵаІеРгойІеЗігіп^ (арр_Ыате, 'попхіор', 

Таіхе', ЫеѵѴаІие, хігеоі (ИелѵѴаІие), іп^ІПЧате); 
іі ЗігСотр ('Іаіхе', N^>/3^6) < > 0 ІЬеп 
попЗіор : = Ігие; 

епсі; 

{ Извлечение ключей командной строки } 

ргосесіиге СеіЗѵѵіІсЬех; 

ѵаг 

і: Іпіе^ег, 

5: Зігіпв [128]; 

С: СЬаг, 

Ьерп 

іог і ; = 1 Іо РагатСоипІ сіо Ье&іп 
5 : = РагатЗіг (і); 

С : = ирсахе (3[1]); 

іі (и п 8 1Ь (3) > 1) апа ((С = •-•) ог (С = V')) ІЬеп 
сахе ирсахе (3[2]) оі 
'ГЯ': попЗіор : = Ігие; 

'5': попхіор : = Саіхе; 
епсі; 
епсі; 
епсі; 

{-Методы ЗСАррІісаІіоп-} 

{ Создание объекта ЗСАррІісаІіоп } 
сопхігисіог 5САрр1ісаІіоп.ІпіІ(А1Чате: РСЬаг); 

Ье^т 

ТАррІісаІіоп.ІпіІ (АІЧате); 

ІпііЗухСоІогАггау; { Инициализация цветов } 

ЬоасІЗеІІіпір; { Загрузка начальных настроек } 

Сеі5\ѵіІсЬех; { Обработка ключей командной строки } 

ІГ попЗіор ІЬеп Ье&іп 

СЬап^еЗухІетСоІогх; { Изменение цветов по ѴІІЧІ } 

РохЮиііМехха^е(О); { Немедленный выход } 
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ОБЪЕКТНО-ОРИЕНТИРОВАННОЕ ПРОГРАММИРОВАНИЕ В СРЕДЕ ТШВО РА5САБ ДЛЯ \ѴШОО\Ѵ$ 


епд; 

епд; 

{ Инициализация окна приложения } 
р госед иге ЗСАррЬсаіюпіші МаіпѴѴіпдоѵ, 

Ьерп 

МаіпѴѴшдоѵѵ : ■ N еѵ( РЗСѴѴшдоѵ, Іші (піі, ’ЗеІ Зуаіет Соіог*')); 
епд; 

{-Методы ЗОѴіпдокг-} 

{ Создание объекта ЗСѴѴіпдоѵ и дочерних окон } 

сопхігисіог 5СѴѴшдо\ѵ.1тІ(АРагепІ: РѴѴіпд спѵаОЬ}есі ; АТііІе: РСЬаг); 

ѵаг 

АЗЫ: РЗЫіс; 

АВіп: РВиііоп; 

Ьерп 

ТѴѴіпдоѵ.ІпіІ (АРагепі, АТііІе); 

Аііг.Мепи : * ЬоадМепи (НІпаіалсе, РСЬаг (»д_Мепи)); 
ѵііЬ Аііг до Ьерп 

X : - 10; V : = 10; Н : * 460; \Ѵ : = 615; 

епд; 

ВиііопОоѵп : * Саке; 

СЬап&ед : 3 Саке; 

АггокСигвог : * ЬоадСилог (0, ідс Аггоѵ); 

СгожНаігСигвог : = ЬоадСигаог (0, ідс_Сгож); 

КедСоІог : * 0; 

СгпСоіог : * 0; 

ВІиСоІог : = 0; 

ЗатрІеСоІог : * 0; 
ѵііЬ ЗатрІеКесі до Ьерп 

ЬеЙ : = 200; Тор : = 150; Ві&Ы : * 300; Воііот : - 230; 
епд; 

ЗВагКед : * Ига (РЗсгоІІВаг, Іпіі(@5еІС, к1_5ВагКед, 50, 20, 250, 0, ігие)); 
ЗВагСга : = N6^ (РЗсгоІІВаг, Іпіі(@5е1С, ідЗВагОт, 50, 60, 250, 0, Ігие)); 
ЗВагВІи : = N 0 * (РЗсгоІІВаг, Іпіі«а>5е1С, ід_5ВагВ1и, 50, 100, 250, 0, Ігие)); 
АЗЫ : = Иеѵ(Р5іаІіс, Іпіі(@5е1С, 0, Кед\ 5, 20, 40, 20, 3)); 

АЗЫ : = Nеѵ(Р5Ыіс, Іпіі(@8еІС, 0, Сгееп\ 5, 60, 40, 20, 5)); 

АЗЫ : = Ыеѵ(Р5Ы»с, Іпіі(@5е1С, 0, В1ие\ 5, 100, 40, 20, 4)); 

АЗЫ : « ІЧеЦРЗЫІс, Іпіі(@5е1С, 0, Сок>г\ 235, 240, 40, 20, 5)); 

ЗТхіКед : = Ыеш(Р5Ыіс, Іпіі«а>5еІС, ід_5ГГхіКед, ООО*, 310, 20, 40, 20, 3)); 
ЗГхіСтп : - Иеш(Р5Ыіс, Іпіі(@5е1С, ід ЗГхіСгп, 000‘, 310, 60, 40, 20, 3)); 
ЗТхіВІи : = Nеѵ(Р5Ыіс, ІпіІ(@5е1С, ід_5ТхіВ1и, '000*, 310, 100, 40, 20, 3)); 
АВіп : = Иеѵ(РВиІІоп, Іпіі(@5еІС, ід_5еіВіп, *5еГ, 50, 150, 80, 40, Саке)); 
АВіп : = Ыеѵ(РВиІіоп, Іпіі(@5е1С, ід_КеаеіВіп, 'КеаеГ, 50, 210, 80, 40, іаке)); 
АВіп : = Ыеѵ(РВиІІоп, Іпіі(@ЗеІС, ід_5аѵеВіп, 'Заѵе', 50, 270, 80, 40, Саке)); 
АВіп : * ІЧе%ѵ(РВиІІоп, Іпіі(@5е1С, ід_ОиііВіп, 'ОиіГ, 50, 330, 80, 40, ігие)); 
епд; 

{ Если окно может закрыться, возвратить ігие } 

Сипсііоп ЗСѴѴіпдоѵ.СапСІоае: Вооіеап; 
ѵаг Апаѵег. іпіе^ег, 

Ьерп 

СапСІоае : » Ігие; 
іС СЬап&ед іЬеп Ьерп 

Апаѵег : * Меааа^еВох (Н\Ѵіпдоѵ, 'Заѵе Соіога ЬеСоге циііііп^?', 

'Ріеаае апаѵег', тЪѴеаМоСапсеІ ог тЬ_ІсопОиеаііоп); 
іС Апаѵѵег * ідѴеа іЬеп СапСІоае : = ЗаѵеЗеіііпр 
еке іС Апаѵег = ідСапоеІ іЬеп СапСІоае : = Саке; 
епд; 
епд; 

{ Переустановка системных цветов на ранее сохраненные } 

р госед иге ЗС\Ѵіпдаш.Кеаеі5уаІетСо1ог5; 

ѵаг 

і: Іпіе^ег 
Ьерп 

Сог і : * 0 іо соІогЕпдСоІога до ѵііЬ ЗуаСокэгАггау [і] до 
СиггепіСоІог : = ОгірпаІСоІог, 

СЬап&ед : - Саке; 
епд; 

{ Изменение класса окна для регистрации пиктограммы ) 
р госед иге ЗСѴѴіпдоѵ.СсіѴ/шдоѵрСІаж (ѵаг АѴѴпдСІаж: ТѴѴпдСІаж); 

Ьерп 

ТѴѴшдоѵ.СеіѴѴтдоѵСІаж (АѴѴпдСІаж); 

АѴѴпдСІаж.Ысоп : * Ьоадісоп (НІпаіапсе, РСЬаг (ід_Ісоп)) 
епд; 

{ Начальная настройка объекта ЗСѴѴіпдоѵ } 
р госед иге 5С\Ѵшдоѵ^іирѴѴшдоѵ; 

Ьерп 

ТѴѴшдочѵ.5еІ ирѴѴіпдоѵѵ; 

5ВагВед л 5еіКап^е(0, 255); 

ЗВатОгп л 5еіКапве(0, 255); 

ЗВагВ1и~.ЗеіКапде(0, 255) 
епд; 


{ Установка полос прокрутки по выбранному цвету } 

р госед иге ЗСЛѴшдоѵ-ЗупсЬгопігеЗсгоІІВага; 

ѵаг 

ОитптуМар Ттежа^е; 

Ьерп 

5ВагК.ед~.5еіРоаіІіоп (ЗатрІеСоІог апд КедМаак); 

5ВагСгп л ЗеіРоаіІіоп ((ЗатрІеСоІог апд СгпМаак) акт 8); 

ЗВагВІ и л .5еІ Розіі іоп ((ЗатрІеСоІог апд ВІиМазк) аЬг 16); 

ЗВагКедЕѵепі (ОиттуМз^); 

ЗВагСтЕѵепі (ОитшуМа^); 

ЗВагВІцЕѵепі (І)иттуМз&); 
епд; 

{ Отображение диалогового окна “АЪоиі** } 
р госед иге ЗСѴѴіпдоѵ.СМАЬоиі (ѵаг М$р ТМеаза^е); 
ѵаг 

Оіаіор ТОиіІор 
Ье^іп 

ОіаІо^Лпіі (@5еІС, 'АЬоиі'); 

РіаІо^Рхесиіе; 

ЕНак>^Е)опе; 

епд; 

{ Выполнение команды 'Ехіі' } 
р госед иге ЗСѴѴіпдоѵ.СМОиіі (ѵаг ТМежа^е); 

Ьерп 

Ро5іОиііМежа^е(0): 

епд; 

{ * Резиновая линия**, отображаемая при копировании цвета } 
ргоседиге ЗСѴѴшдоѵЛЗгаѵКиЬЬегЪапд; 

Ье^ш 

МоѵеТо (Г)с, ІіпеХІ, ІіпеѴІ); 

ІіпеТо (Ос, ІіпеХ2, ЬпеѴ2); 
епд; 

{ Если точка (X, V) находится в цветовом прямоугольнике, вернуть ігие } 
Сипсііоп ЗС\Ѵіпдоѵ.Іп5ідеСо1огКесі (X, V: Іпіе^ег; ѵаг Іпдех: Іпіе^ег): Вооіеап; 
ѵаг 

СижогЕосаііоп: ТРоіпі; 
і: Іпіе^ег, 

Ье^ш 

СигеогЬосаІіопЛ : = X; 

Сиг5огЬосаіюп.Ѵ : = V; 

іС РіІпКесі (ЗатрІеКесі, СигеогІ^осаіюп) ІЬеп Ьерп 

Іпдех : = -1; (Внутри прямоугольника} 

Ехіі 
епд еке 

Сог і : = 0 іо Сокэг ЕпдСоІоге до 

іС РіІпКесі(Зу5Со1огАггау(і]5СКесі, Сигхогіохаіюп) ІЬеп Ье^т 
Іпдех : = і; 

Ехіі 

епд; 

ІпкідеСоіогКесі : = Саке; 
епд; 

{ Обработка нажатия левой клавиши мыши } 
ргоседиге 5С^іпдоѵ.>ѴМЬВиІіопОоѵп (ѵаг Мар ТМежа^е); 

Ьерп 

іС поі ВиііопОоѵп іЬеп ѵііЬ М$^ до 

іС ІпаідеСоІогКесІ (ЬРагатЬо, ЬРагатНі, Ога^рп^Опрп) 

ІЬеп Ъсрп 

Ос : = ОеЮС (Н\Ѵіп доѵ); 

ІіпеХІ : = ЬРагатЬо; 

ІіпеѴІ : = ЬРагатНі; 

ІіпеХ2 : = ІіпеХІ; 

ІіпеѴ2 : = ІіпеѴІ; 

ЗеіКОР2 (Ос, г2_Ыоі); 

ОгаѵКиЬЬегВапд; 

ВиііопОоѵп : = ігие; 

ЗеіСигаог (СгожНаігСигаог); 

ЗеіСаріиге (НѴѴіпдоѵ); 
іС Ога^рпв^Кй 1 > = 0 іЬеп Ьерп 

ЗатрІеСоІог : = 5уаСо1огАггау(0га^т20гі^т].СиггепіСо1ог, 
ЗупсЬгопігеЗсгоІІВаге 
епд 
епд 
епд; 

{ Обработка отпускания левой клавиши мыши } 
ргоседиге 5С\Ѵіпдоѵ.\ѴМІБиііопІІр(ѵаг Мар ТМежарг); 
ѵаг 

Іпдех: Іпіе^ег; 

ЫпѵСоІог ТСоІогКеС; 

Ьерп 

іС ВиііопОокт іЬеп кліЬ Ма$ до Ьерп 
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іСЛпхісіеСоІогКесІ (ІРагашЬо, ЬРагатНі, Ітісх) ІЬсп 

ІС (Іпсіех < > І)га$ц 5 Ш{{Огі$ш) апсі (Іпсіех > = 0) ІЬсп Ьеуп 
СЬяодесі : - ігие; 

ІС Ога^уп^Опуп > = 0 ІЬеп 

НсѵрСоіог : = 8ухСокэгАггау(Огг^пяОгіуп].СштепіСо1ог 
еке 

МеѵСоіог : = ЗатрІеСоІог, 
$ухСо1огАггау[Іпсіех].СштепіСо1ог : * ЫеѵСоіог, 
ІпѵаІісіаІеКесі (НѴѴіпсіоѵ, ші, Сакс) 
епсі; 

ОгаѵѵКиЬЬсгВапсі; {Егахе Іахі Ііпс} 

5еіКОР2 (Ос, г2_В1аск); 

ВиііопОоѵп : * Сакс; 

ЗеіСигхог (АггоѵСигвог); 

КеІеахеЭС (НѴ/тсІспѵ, Ос); 

КеіеахеСаріиіе 

егкі 

епсі; 

{ Отработка перемещения мыши } 

ргосесіиге 5С\Ѵіпсіоѵ.\ѴММоихеМоѵе(ѵаг Мху ТМехха^е); 

Ьеуп 

іі ВиііопОоѵп іЬсп Ьеуп 

ОгаѵКиЬЬсгЬапсі; {Удаление старой линии} 

ѵііЬ Мх^ сіо Ъеуп 

ЬіпеХ2 : * ЬРагатЬо; 

ІіпеѴ2 : ■ ЬРагатНі; 

ПгаѵѵКиЬЬегЬапсі {Огри совка новой линии} 

епсі 
епсі 
епсі; 

{ Отработка события в красной полосе прокрутки} 
ргосесіиге 5С\Ѵіпсіоѵ.5ВагКес1Еѵеп1 (ѵаг Мху ТМехха^е); 
ѵаг 

С: Аітау [0.3} оі СЬаг; 

Ьеуп 

КесіСоІог : - 5ВагКесі Л .СеіРохііюп; 

Іпі25іг(КесіСо1ог, 3, С); 

5ТхіКесГ.5еіТехі(С); 

ЗатріеСоіог : * КОВ (КесіСоІог, ОгпСоІог, ВІиСоІог); 
ІпѵаІісіаІеКесі (ЖѴіпсіоѵ, @$атр1еКесі, іаке) 
епсі; 

{ Отработка события в зеленой полосе прокрутки } 
ргосесіиге ЗСѴѴшсіоѵЗВагОгпЕѵепі (ѵаг Мху ТМехха^е); 
ѵаг 

С: Аггау [0-3] оі СЬаг; 

Ьеуп 

ОгпСоІог : = 5ВагСгп~.СеіРохйіоп; 

Іпі25іг(СгпСо1ог, 3, С); 

5ТхіОпГ.5еіТехІ(С); 

ЗатріеСоіог : = КОВ (КесіСоІог, ОгпСоІог, ВІиСоІог); 
ІпѵаІісіаІеКесі (КѴѴіпдоѵ, @5атріеКесі, Саке) 
епсі; 


ЗатріеСоіог : - КОВ (КесіСоІог, ОгпСоІог, ВІиСоІог); 

ІпѵаІісіаІеКесі (НѴ/шсіоѵ, @Затр1еКесі, Саке) 
епсі; 

ргосесіиге 5СЛѴіпс1оѵ.5еіВіпЕѵепі (ѵаг Мху ТМехха^е); 

Ьеуп 

СЬапвеЗухіетСоіогх 

епсі; 

ргосесіиге ЗСЛѴіпсігіѵ.КехеіВіпЕѵепІ (ѵаг Мху ТМехха^е); 

Ьеуп 

КехеіЗухіетСоіогх; 

СЬапзеЗухіетСоіогх 

епсі; 

ргосесіиге 5С\ѴіпсіаѵЗаѵеВіпЕѵеп( (ѵаг Мху ТМехха^е); 

Ьеуп 

іі ЗаѵеЗеіІіпу ІЬеп СЬаодес! : * Саке; 
епсі; 

ргосесіиге 5С\Ѵіпсісж.ОиііВіпЕѵепІ (ѵаг Мху ТМехха^е); 

Ьеуп 

РохЮиіі Мехха^е (0); 
епсі; 

ргосесіиге 5С\Ѵіпсіаѵѵ.РаіпІ (РаіпіЭС: НЕ)С; ѵаг РаіпІІпГо: ТРаіпіЗігисі); 
ѵаг 

ОкіВгихЬ, ТЬеВгихЬ : НВгихЬ; 

і : Іпіе$ег, 

ргосесіиге ЗЬоѵЗухСоіог (й Іпіедег); 
ѵаг 

ЗухСоіогВгихЬ : НВгихЬ; 

ОісіВгихЬ : НВгихЬ; 

ЗСИаше : РСЬаг, 

Ьеуп 

ѵііЬ 5ухСоіогАггау[і], ЗСКесі сіо Ьеуп 

ЗухСоіогВгихЬ : = СгеаіеЗоІісіВгихЬ (СиггепіСоіог); 

ОісіВгихЬ : « ЗвіесіСКуесі (РаіпіІХП, ЗухСоіогВгихЬ); 

КоипсіКесІ (РаіпЮС, ЬеСі, Тор, Кі&Ы, Воиот, 5, 5); 

Зе1есіОЬ}есІ (РаіпіЕ)С, ОісіВгихЬ); 

ОеіеіеОЬіесі (ЗухСоіогВгихЬ); 

ЗСИате : = ЗухСоІо^ате [і]; 

ТехіОиі (РаіпЮС, ЬеЙ - 125, Тор, ЗСИате, ЗігЬеп (ЗСЫате)) 
епсі 
епсі; 

Ьеуп 

ТЬеВгихЬ : = СгеаіеЗоІісіВгихЬ (ЗатріеСоіог); 

ОісіВгихЬ : * 5еіесЮЬ]ес1 (РашНХП, ТЬеВгихЬ); 
ѵііЬ ЗатрІеКесі сіо 

КоипсіКесі (РаіпіЕХП, ЬеСІ, Тор, Кі&ЬІ, Воііот, 10, 10); 

ЗеіесіОЬіесі (РаіпНКИ, ОісіВгихЬ); 

ІЗе1еІеОЬ}есІ (ТЬеВгихЬ); 

Сог і : * 0 іо соІогЕпсіСоІогх сіо 
5Ьо\ѵ5ухСоіог(і) 

епсі; 


{ Отработка события в голубой полосе прокрутки } 
ргосесіиге 5С\Ѵіпсіоѵѵ.5ВагВ1иЕѵепІ (ѵаг Мху ТМехха^е); 
ѵаг 

С: Аггау [0-3] оС СЬаг; 

Ьеуп 

ВІиСоІог : = 5ВагВ1и Л .СеіРохіііоп; 

1пі25іг( ВІиСоІог, 3, С); 

5ТхіВіи Л ЗеіТехі(С); 


{ 5Ѵ5СОШКЛС, (с) 1991 Ьу Тош Зѵап.} 

САРПОЫ “АЬоиі 5ухСо1ог“ 





ВЕСІЫ 




# іпсіисіе < Е:\ТР\Ѵ\0\ѴЬ\ѵіпсіоѵх.Ь > 

СОІЧТКОЬ 200 

101, 




“5ТАТІС“, ѴѴ5 СНИХ) | ѴѴ5_Ѵ15ІВЕЕ | ОхЗЦ 


14,36, 17, 

17 

200 ІСОИ хухсоіог-іоо 

СОІЧТКОЬ “ЗухСоіог - 5еі хухіет со1огх“ 

106, 



100 МЕЫІІ ЬОАЕЮМСАІХ МОУБАВЬЕ РІЛКЕ ОІЗСАКОАВЬЕ 

“5ТАТ1С“, ѴѴ5 СНІЫЭ | \Ѵ5 ѴІЗІВЬЕ, 


15, 11, 99, 

10 

ВЕСІЫ 

СОІЧТКОЬ “&Ок“ 

1 , 



ГОРИР “АМепи- 

“ВІЛТОЫ“,\Ѵ5_СНІШ | \Ѵ5_ѴІ51В^ | \Ѵ8_ТАВ5ТОР, 49, 77, 35, 13 

ВЕСПЧ 

СОГЧТКОЬ “ѴѴгіііеп ш ТигЬо Рахсаі Сот \Ѵіпсіошх“ 

107, 



Мепиііет “ААЬоиі хухсоіог... - , 101 

-5ТАПС-, \Ѵ5_СНІШ | \Ѵ5 ѴІЗІВЬЕ, 


4, 21, 120, 

10 

МепиПет “ЕАхіі“, 102 

СОКТВОЕ “Соруп^Ьі (с) 1991 Ьу Тот 5сѵап“ 

108, 



ЕN^ 

“5ТАТІС“, \Ѵ5 СНІЬО | \Ѵ5 ѴІЗІВЬЕ, 


14, 63, 105, 

10 

ЕИЛ 

СОІЧТКОЕ “Ѵегхюп 1.00“ 

109, 




“5ТАТ!С“, \ѴЗ СНІШ | \Ѵ5 ѴІЗІВЬЕ, 


45,52, 44, 

9 


АВОЦТ РІАІХКх ОІ5САКОАВЦЕ ЬОАЕЮЫСАІХ РІЖЕ МОѴЕАВЬЕ 29,48,128,99 ЕІ*Ю 
ЗГѴЪЕ \Ѵ5_РОРНР | ѴѴ^ САРПОИ | \ѴЗ_5Ѵ5МЕМи | 0х80Ь 


ѵаг 

ЗСАрр: ЗСАррІісаііоп; 
Ьеуп 

ЗСАррЛпіі (арр Иате); 
5САрр.Кип; 
5САррХ)опе 
епсі. 
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«С -Сервис» 

' МОЩНАЯ ИНСТРУМЕНТАЛЬНАЯ ОБОЛОЧКА 

ДЛЯ ПРО ГРАММИСТОВ НА ЯЗЫКЕ СИ 

Самый высокий уровень сервиса ! 

Работа без файлов — только с объектами и функциями, 
все остальное оболочка сделает за Вас ! 

Мгновенная фиксация синтаксических ошибок до компиляции ! 

Новая разработка предприятия "Семигор" — 
такого сервиса вы не найдете 
в оболочках МісгозоЛ, Вогіапа, 2огіесЬ. 

Инструментальная оболочка включает: 

□ уникальное средство создания, веденния и модификации деревьев проекта; 

СИ настраиваемый многооконный редактор; 

□ средства фиксации языковых ошибок непосредственно в месте и в момент возникновения 
(до компиляции !!!) на основе “непрерывного” и “мгновеннного” лексического и синтак- 
сического анализа; 

СИ средства визуальной идентификации логической структуры проекта (построение дерева 
иерархии вызовов функций) — полная ясность замысла и его воплощения; 

О средства автоматической диспетчеризации файлов, предъявляемых к компиляции (в кото- 
рых размещаются функции, вводимые пользователем) , по эффективным стратегиям — за- 
будьте про файлы и Вы попадете в страну объектов и функций, в которой так легко ды- 
шится настоящему знатоку С; 

О средства ведения разнообразных таблиц: функций проекта с их описанием; глобальных пе- 
ременных с указанием их типов и функций, на которые данные объявления распространя- 
ются; констант и типов переменных — Вы будете знать все ! 

СИ средства визуального отслеживания правильности создаваемых языковых конструкций по 
дереву синтаксиса языка С — заботливый МЕНТОР всегда с Вами ! 

Оболочка “С-Сервис” отвечает логике разработчика: Алгоритм (спецификации) — Про- 
грамма (функции) — Документация. При этом на каждом этапе Вам гарантируются ясный 
обзор всего проекта, соответствие архитектуре и большой сервис. 

В следующей версии в состав инструментальной оболочки будет включен оригинальный 
компилятор Тгее Сотрііег, обладающий сверхвысоким быстродействием (время компиляции 
— несколько секунд при любом объеме листинга!). 

Техническая документация на русском языке. Поставляются бесплатные инсталляции. Га- 
рантия 1 год. 

В следующей версии — сверхбыстрая компиляция ! ! ! 


СССР, 440000, 
г. Пенза, а/я 72 


«СЕМИГОР» 


Телефакс: (841-2) 64-78-50 
Телетайп: 155349 РИФ 
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Новый компилятор фирмы Вогіапй — Вогіапд С+ + 2.0 
имеет все средства, необходимые для создания Шпдот- 
программ, и позволяет обходиться без Місгоюр 5ЭК. 


Компилятор ВогІапсІ С + + 2.0. 
Создание Ѵ/іпсіоѵѵв-программ без 5ѲК 


До недавнего времени на рынке инструментальных 
программных средств было всего несколько компиля- 
торов языка С, поддерживающих разработку АѴіпсІо^ѵз- 
программ. Эти компиляторы — МісгозоЙ С и 
ХогіесЬ С++ — при создании >Ѵіпсіо>ѵ5-программ тре- 
бовали использования МісгозоН АѴіпскиѵз 8оН\ѵаге Ое- 
ѵеіортепі Кіі (ЗЭК). 

С появлением ВогІапсІ С++ 2.0 (ВСРР) ситуация 
изменилась. ВСРР имеет все средства, необходимые 
для разработки >Ѵіпсіо>ѵ5-программ; использования 
5ЮК при этом не требуется. 

С одной стороны, ВСРР — это новый, более разви- 
тый представитель семейства компиляторов 
ТигЬо С/ТигЬо С++. С другой стороны, он является 
зачинателем новой группы компиляторов С/С++, под- 
держивающих разработку ХѴіпсклѵз-программ. По со- 
общениям фирмы, в дальнейшем будут развиваться 
оба семейства продуктов — компилятору, работающие 
в среде 008 (ТигЬо С++), и компиляторы, работа- 
ющие в среде >Ѵіпсіо\ѵз (ВогІапсІ С++). Последние бу- 
дут ориентированы преимущественно на разработку 
ЛѴі п (5олѵ5- п рограм м . 

Интегрированная среда разработчика (ИСР) ВСРР, 
уже знакомая пользователям ТигЬо С++, соответствует 
рекомендациям стандарта 8АА/СІІА (Зузіеш Аррііса- 
Ііоп АгсЬйесіиге/Соштоп ІІзег Ассезз) фирмы ІВМ и 
поддерживает многооконное редактирование файлов, 
работу с мышью, текстовый редактор с широкими 
возможностями, а также имеет встроенный отладчик. 
Помимо этого, в комплект ВСРР входит отладчик 
ТигЬо ОеЬи^ег (ТО) с интерфейсом, похожим на 
ИСР компилятора. ТигЬо ОеЬи^ег позволяет отобра- 
жать исходный текст программы, содержимое реги- 
стров процессора и памяти и устанавливать точки 
прерываний. С помощью ТО можно отлаживать про- 
граммы, созданные при помощи компиляторов как 
фирмы ВогІапсІ, так и фирмы МісгозоН. Используя 
входящий в комплект профилировщик ТигЬо РгоПІег 
(ТР), можно анализировать производительность про- 
граммы и определять те участки, которые требуют 
оптимизации. Как и компилятор ТигЬо С++, ВСРР со- 
держит два компилятора. Один из них — компилятор 


С, поддерживающий стандарт АЫ5І С, другой — ком- 
пилятор С++, поддерживающий спецификацию АТ&Т 
версии 2.0. Помимо компилятора с интегрированной 
средой поставляется пакетный компилятор. 

Кроме упомянутых, в комплект ВСРР входят еще 
два компилятора (ВСХ и ВССХ), работающие в за- 
щищенном режиме процессора и позволяющие 
использовать при компиляции программ всю доступ- 
ную расширенную память. 

Компилятор ВСРР поддерживает встроенный ассем- 
блер, не требующий, как в предыдущих версиях, за- 
грузки ТигЬо АззешЫег или МісгозоМ Масго АззешЫег 
для компиляции программ. Также в состав ВСРР вхо- 
дят библиотеки классов С++, включая потоки и кон- 
тейнеры (связанные списки, стеки, очереди и т.п.). 

Но самой замечательной возможностью нового ком- 
пилятора фирмы ВогІапсІ является поддержка создания 
ЛѴі п <іо\ѵ5- п рограм м . 

Компилятор 

Компилятор ВСРР стремится полностью заменить 
компилятор МісгозоН С (М5С), поэтому он более со- 
вместим с М5С, чем предыдущие компиляторы фирмы 
ВогІапсІ. Давайте сравним эти два компилятора. 

Примерно половина функций библиотеки Вог- 
ІапсІ С++ имеет те же названия, что и у М8С. Это свя- 
зано в первую очередь с тем, что оба компилятора 
поддерживают стандарт АЫ5І С. Ряд функций, вклю- 
ченных в библиотеку ВогІапсІ С++, выполняют те же 
действия, имеют те же формальные параметры, что и 
функции библиотеки МісгозоН С, но наименования 
параметров и функций ВСРР и М8С различны. В за- 
головочных файлах ВСРР имеется ряд макросов для 
поддержки вызовов М8С-функций с преобразованием 
их в вызовы функций ВСРР. Для облегчения компиля- 
тору вызова этих функций можно использовать макрос 
М5С. 

Ряд заголовочных файлов ВСРР и М8С имеют раз- 
личные наименования, но в большинстве своем они 
совместимы. Различия в наименованиях файлов заго- 
ловков приведены в таблице 1 . 
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КОМПИЛЯТОР ВОКЬАМ) С++ 2.0. СОЗДАНИЕ >ѴІШО\Ѵ5-ПРОГРАММ БЕЗ ЗОК 


Таблица 1. Различия в наименованиях файлов заголовков 


ВСРР 2.0 

МЗС 6.0 

АН ОС . Н 

МАИ. ОС . Н 

йІР.Н 

ЭІРЕСТ.Н 

МЕН.Н 

МЕМ0ВѴ.Н 


Для компиляции >Уіпбоѵѵз- программ в ВСРР 
используется макрос _>Ѵіпбо>ѵ5, позволяющий опреде- 
лять, какие >Ѵіпбоіѵ5-функции необходимы при ком- 
пиляции. 

Как уже было сказано, ВСРР поддерживает встро- 
енный ассемблер. Для включения в текст программы 
ассемблерных вставок в МЗС используется ключевое 
слово _а$т: 

_азт { 

тоѵ ах,1 

хог Ьх,Ьх 

> 

В ВСРР можно применять как ключевое слово 
_а$т, так и ключевое слово а$т: 

_а$т тоѵ ах,1 
или: 

а$т тоѵ ах,1 

Помимо встроенного ассемблера для обращения к 
регистрам в ВСРР, как и в ТигЬо С 2.0, и ТигЬо С++, 
можно использовать псевдорегистровые переменные: 

АХ = 2; 

Создание \Ѵіпбо\ѵ$-программ 

Как отмечалось выше, в состав ВСРР входят четыре 
компилятора. Два из них работают с интегрированной 
средой, два — с командной строкой. Два компилятора 
(один с интегрированной средой и один пакетный) ра- 
ботают в реальном режиме процессора, остальные 
два — в защищенном режиме процессоров 80286 и 
выше. Все компиляторы позволяют создавать >Ѵіпбо\ѵз- 
программы, работающие в защищенном режиме (в 
стандартном и расширенном режимах АѴіпбото). Ком- 
пиляторы не создают кода для работы ИОЗ-программ в 
защищенном режиме. 

Компиляция в защищенном режиме позволяет 
использовать до 15 Мбайт памяти под буферы и созда- 
ваемые объектные файлы, тем самым уменьшая число 
обращений к диску и существенно повышая скорость 
компиляции. Компиляция в защищенном режиме воз- 
можна на машинах с процессорами 80286 и выше и 
640 Кбайтами оперативной памяти. Для работы ком- 
пилятора ВСХ требуется 576 Кбайт расширенной или 
дополнительной памяти, а для компилятора ВССХ — 
450 Кбайт. 

Как известно, для успешного создания >Ѵі пост- 
программ компилятор должен поддерживать: 


- соглашение о вызовах типа Разсаі (параметры 
передаются в стек слева направо, и подпрограмма 
сама очищает стек по завершении работы); 

- ключевые слова пеаг и іаг соответственно для 
16-битных внутрисегментных ссылок и 32-битных 
межсегментных ссылок (статические данные 
АѴіпбодѵз-программ доступны через указатели типа 
пеаг, а указатели на функции >Уіпбо^ѵз должны быть 
типа ?аг); 

- генерацию специального пролога и эпилога. 

Компилятор ВСРР удовлетворяет всем перечислен- 
ным требованиям и помимо АѴіпбоіѵз-функций также 
позволяет создавать динамически загружаемые библи- 
отеки ШІХ). 

Так как файлы заголовков, используемые при со- 
здании >Ѵіп(кяѵз-программ, имеют довольно большие 
размеры (один файл >ѴШОО>У5.Н больше 120 Кбайт), 
очень удобно использование реализованной в ВСРР 
возможности создания предкомпилированных файлов 
заголовков . В процессе компиляции файла заголовков 
на диск записывается таблица символов. При повтор- 
ной компиляции программы файл заголовков не ком- 
пилируется, а загружается уже готовая таблица. Необ- 
ходимость предкомпиляции файлов заголовков указы- 
вается опцией командной строки компиляторов ВСС и 
ВССХ: 

ВСС -Н или ВССХ -Н 

или командой Сотрііег | Собе Сепега- 
1іоп|Ргесотрі1еб Неабега команды меню Орііопз 
ИСР. В первом случае создается файл ТСЭЕР.ЗѴМ, а 
во втором — файл РКОЛЕСТ.ЗѴМ, где РКОЛЕСТ — 
имя текущего проекта. 

Таблица 2. Время компиляции, с 


Компиляция 

МЗС 6.0А 

ВСС 

всех 

ВСС* 

ВВСХ* 

1 .. 

7.63 

5.79 

5.29 

4.84 

5.82 

2 

5.92 

4.57 

4.56 

2.42 

2.73 


* Использовались предкомпилированные файлы заголовков. 
•• Компиляция с использованием расширенной памяти. 

Опции М5С 6. 0 А; 

СХ -С*ѵ -А5 ѵіпЬеІІох /Пик ПЬѵЛіЬ $1іЬсеѵ.иЬ 
Опции ВС+ +: 

Без предкомпиляции: 

ВСС ЛѴ5 ѵшЬеІІох 
ВССХ ЛѴ5 ѵшЬеІіох 
С учетом предкомпиляции: 

ВСС -Н ЛѴ5 ѵіпЬеІІох 
ВССХ -Н ЛѴ5 ѵіпЬеІІох 


Как видно из приведенной таблицы, при повторной 
компиляции с использованием предкомпилированных 
файлов заголовков время компиляции сокращается 
почти в два раза. 

Из той же таблицы видно, что компиляция, исполь- 
зующая расширенную память, выполняется суще- 
ственно быстрее. 
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Средство для создания 
и редактирования ресурсов — 

\ѴНіІе\ѵаіег Кезоигсе Тооікіі 

Ресурсы >Ѵіпсклѵ5-программ — это блоки диалога* 
графические изображения* курсоры* иконки* меню и 
строки текста. Существует возможность динамического 
создания ресурсов во время выполнения программы* 
но чаще всего ресурсы создаются с помощью специа- 
льных редакторов и подключаются к исполняемому 
файлу. В отличие от динамически создаваемых ресур- 
сов* статические (подключенные к .ЕХЕ-файлу) ре- 
сурсы загружаются в память только при необходимос- 
ти и в дальнейшем могут быть выгружены из памяти. 
Если одновременно запущено несколько копий одной 
и той же программы* то все они будут использовать 
только одну копию ресурса в памяти. Использование 
статических ресурсов существенно облегчает 
локализацию программных продуктов (перевод ин- 
терфейсной части прикладной программы на другой 
язык). 

Включенный в состав компилятора ВСРР редактор 
ресурсов \ѴНі(ешаіег Кезоигсе Тооікіі (\ѴКТ) 
позволяет создавать и редактировать ^Ѵіпбодѵз- 
ресурсы. В состав >ѴКТ включены редакторы для 
всех стандартных ресурсов — каждый из них 
представлен иконкой-кнопкой в основном окне 
\УКТ. \ѴКТ также имеет два окна для просмотра 
ресурсов в файлах (.РЕ8, .ОІХ или .ЕХЕ), 
копирования ресурсов* их переименования и 
включения ресурсов прямо в .ЕХЕ-файлы. >УКТ 
создает файлы* совместимые с компилятором 
ресурсов РС.ЕХЕ (входящим в состав как 
МісгозоГі 8ЭК* так и ВСРР), так что этот 
компилятор можно использовать для записи 
ресурсов в .ЕХЕ-файлы. В большинстве случаев 
использования компилятора ресурсов КС. ЕХЕ не 
требуется. 

Редактор ресурсов \ѴКТ разработан с таким 
расчетом, чтобы заменить утилиты ЗОКРаіпІ и 
Оіаіов, входящие в состав МісгозоН 80К. Фун- 
кционально эти средства одинаковы, но АѴКТ 
использует более наглядный, интуитивный ин- 
терфейс и имеет ряд расширений* например по- 
зволяет тестировать создаваемые меню. Недо- 
статком >ѴКТ является то, что с его помощью 
невозможно редактировать шрифты. 

ТигЬо ОеЪи§§ег Гог >Уіп(1оіѵ$ 

В состав ВСРР входят несколько отладчиков; 
среди них — ТигЬо ОеЬи^ег и ТигЬо ЭеЬи^ег 
Гог >Ѵіпскпѵ5 (ТО\Ѵ). Отладчик ТигЬо ЭеЬи^ег 
для 008-программ хорошо известен программи- 
стам. ТО>Ѵ является новинкой и позволяет 
отлаживать >Ѵіпбо>ѵ5- программы. ТО>Ѵ может 
работать на двухмониторной системе или в каче- 
стве полноэкранной 008-задачи в среде >Ѵіп- 
(Іспѵз. ТО>Ѵ работает в текстовом режиме и 


позволяет по нажатии АИ-Р5 просматривать текущий 
экран \ѴіпсІо\ѵ5. Отладка >ѴіпсІспѵ5- программ требует 
несколько иного подхода* чем отладка обычных 008- 
программ. Вместо пошагового выполнения (которое в 
случае >ѴіпсІо>ѵ5 обычно приводит в цикл работы с со- 
общениями) используются точки останова по сообще- 
ниям (тезза^ез) АѴіпсіоаѵз. С помощью ТЭ\Ѵ можно 
указать как отдельное сообщение* так и целый класс 
сообщений (сообщения от мыши* клавиатуры* систем- 
ные сообщения и т.п.). По сообщению можно остано- 
вить выполнение программы или записать это сообще- 
ние в специальном окне. 

ТЭ\Ѵ позволяет просматривать как локальный, так 
и глобальный хип, загруженные задачи и ОЬЬ-библи- 
отеки, отлаживать динамические библиотеки. 

Возможна отладка программ, созданных с помощью 
компилятора М8С. Для этого необходимо с помощью 
утилиты ТПСОЫѴЕК.Т преобразовать символьные таб- 
лицы из формата М8С в формат Вогіапсі. 

ТЭАѴ и ТигЬо ОеЬи^ег предоставляют уникальную 
возможность выполнения программы на несколько ша- 
гов назад. 


сІетозА 


ёето8+АР8 СОМ (Москва-Вена) 
для обладателей СКВ: 

Оборудование для Вашего офиса: 

■ Официальный дистрибьютер фирмы НежІеН 
Раскагс) предлагает компьютеры, лазерные принтеры, 
плотеры и другое оборудование фирмы со скидкой 
до 32% ! Гарантийное обслуживание 3 года. 

■ Внешние модемы 'йізсоѵегу 2400СМ/0', 
адаптированные к отечественным линиям, эффективно 
работающие в почтовой сети. Модем Науез 
совместимый, имеет коррекцию ошибок и компрессию 
данных (МЫР-5), 2400 ор$, аттестован Минсвязи СССР. 
Гарантийное обслуживание 1 год. 

■ Универсальная внутриофисная телефонная станция. 
3/8, расширяемая до 6/16, входных/выходных линий, 
обеспечивает подключение телефонных аппаратов 
любых типов, телефаксов, модемов, автоответчиков. 

Рабочее место в портфеле: 

Портативный компьютер '$ирегНоіе-$Х'. Процессор 
38о$Х, 2МЬ РАМ, жесткий диск 40МЬ, Ѵ&А, З.э 
флоппи дисковод 1.44 МЬ, вес около 2.5 кг^ размеры: 
48x22x5 см, в комплекте портативный ФАКСМОДЕМ, 
возможность работы в системе электронной почты 
РЕЬСОМ, аккумулятор. 

По желанию комплектуется портативным струйным 
принтером В.І-10Е, габариты: 31x22x5 см, вес 1.8 кг, 
лазерное качество, русские шрифты, аккумулятор. 

бетоз/* 


113035 Москва, Овчинниковская наб. д.6 
телефон: 231-21-29, 231-63-95; 

Рах: 233-5016; Е-таіІ: іп(о@Ня.сіето$.$и 
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КОМПИЛЯТОР ВОКІАШ С++ 2.0. СОЗДАНИЕ >ѴІШО\Ѵ$-ПРОГРАММ БЕЗ ЗБК 


К недостаткам ТО>Ѵ относится некорректная работа 
отладчика с некоторыми видеоадаптерами (в частно- 
сти, по завершении работы портится экран на видео- 
адаптерах ЗирегѴСА типа Ѵі(іео7). 

ТигЬо АззетЫег и ТигЬо РгоПІег 

Новая версия ассемблера ТигЬо АззешЫег 2.5 под- 
держивает более гибкий интерфейс с языками высо- 
кого уровня. Несколько директив (МООЕБ, РКОС, 

ехткы, рідвілс, сомм, сшвац рдоисош 

поддерживают спецификатор языка высокого уровня 
(Разсаі, ВА5ІС, РСЖТКАЫ, С, Ргоіо^). Также можно 
указать спецификатор языка в инструкции САЬЦ что 
приведет к генерации кода в соответствии с соглаше- 
ниями о вызовах для данного языка высокого уровня 
(передача параметров и очистка стека). 

Директива ассемблера .МСШЕБ позволяет указать 
спецификатор >ѴШОО>Ѵ8. Это вызовет автоматичес- 
кую генерацию >ѴіпсІспѵ5-пролога и эпилога для данной 
подпрограммы. Директива РІДВІЛСОЕЬ указывает, что 
процедура является точкой входа в ОІХ. 

В состав ВСРР также включена версия ассемблера, 
работающая в защищенном режиме процессора. Эта 
версия позволяет компилировать программы большого 
объема. 

В отличие от МЗС, где компилятор сам выполняет 
необходимую оптимизацию (часто существенно увели- 
чивая время компиляции), в состав ВСРР включен 
профилировщик ТигЬо РгоПІег, позволяющий вручную 
оценить производительность программы. ТигЬо РгоПІег 
дает возможность посмотреть время выполнения каж- 
дой подпрограммы и выявить “узкие места“, которые в 
наибольшей степени влияют на общую производи- 
тельность. 

Документация 

В комплект поставки ВСРР включены девять книг 
документации и справочная система. В документации 


подробно описаны различные аспекты, начиная от 
установки компилятора на жесткий диск, использова- 
ния ИСР и кончая справочником по стандартной биб- 
лиотеке и руководствами по ассемблеру, отладчику и 
профилировщику. Файлы с исходными текстами про- 
грамм, представленных в документации в качестве 
примеров, также включены в комплект поставки. 
Справочная система, доступная из ИСР или вызыва- 
емая при помощи утилиты ТИБЫ*, содержит матери- 
алы по компилятору, стандартной библиотеке, интер- 
фейсу АѴіпсіспѵз Арріісаііоп Рго^гаш Іпіегіасе, а также 
описание структур данных, сообщений и констант 
^іпсіодѵз. На диске имеется файл, вкратце описыва- 
ющий порядок создания \Ѵіпс1о>ѵз- программ с помощью 
С++. 

Несмотря на заверения фирмы о полном отказе от 
МісгозоЙ 5ЭК, для успешного создания \Ѵіпсіолѵ5-про- 
грамм с помощью Вогіапсі С++ требуется как минимум 
пособие, посвященное программированию в среде 
>ѴіпсІо>ѵ5 (подобное тому, что входит в состав МісгозоП 
ЗЭК), или книга Ч.Петзольда. 

Заключение 

Компилятор Вогіапсі С++ имеет все средства, необ- 
ходимые для создания \Ѵіпскпѵ5- программ с использо- 
ванием С, С++ или ассемблера. Ряд фирм заявили о 
выпуске библиотек классов для создания \Ѵіпс1о>ѵ5-про- 
грамм. 

Совсем недавно фирма Вогіапсі выпустила библи- 
отеку классов ОЬцесМіпсІОАѵз, позволяющую упростить 
создание объектно-ориентированных ^іпсіо^ѵз- про- 
грамм. В состав библиотеки входят классы, ориентиро- 
ванные на создание элементов интерфейса — диало- 
говых блоков, меню и т.п. Библиотека также осущест- 
вляет поддержку потокового ввода/вывода. Поставля- 
ется исходный текст библиотеки. 

А.Федоров 


Компьютеризация 
биржевой деятельности 
идет полным ходом 
Биржи мира планируют отказаться 
от своих залов и полностью перевести 
торги в он-лайновый режим. Быстрее 
всего этот процесс идет в области тор- 
говли валютой. Кеиіегв начали испыта- 
ния в реальном режиме своей системы 
Оеа1іп& 2000 в Лондоне и Нью-Йорке. 
Работать она начнет в начале следу- 
ющего года. Оеаііпя 2000 заключает 
сделку автоматически, если цены 
спроса и предложения совпадают. В 
ответ на это Эо\ѵ Допев продаст свою 
биржевую службу ТгасИп^ Зегѵісе, 
чтобы стать владельцем более крупной 
доли в дилерской системе Міпех, кото- 


рая перейдет в он-лайновый режим в 
1993 году. Основными акционерами 
Міпех являются КІШ, Токийская 
валютная биржа и японские банки. В 
результате предпринимаемых действий 
Ооѵѵ Допев войдет в тройку самых 
крупных держателей акций Міпех. 

Кроме того, нью-йоркская биржа 
МегсапШе ЕхсЬап^е подписала согла- 
шение о создании Асееве, биржевой 
он-лайновой системы, работающей 
тогда, когда обычные биржи закрыты, 
для заключения фьючерных сделок по 
нефти и металлам. Система начнет ра- 
боту в конце 1992 года. 

ТНе Теіериііпв НоШпе, 
МоѵетЬег 12, 1991 


БО\Ѵ Д(ЖЕ8 представила службу 
составления подборок под названием 
Расів Оеііѵегесі. Она представляет собой 
поток новостей из информационных 
каналов компании, отобранных в соот- 
ветствии с указанной тематикой, кото- 
рые могут направляться на факси- 
мильные аппараты или в электронные 
почтовые ящики. Подписчики платят 
15 долларов в месяц за подбор матери- 
ала, и еще 1.50 доллара за каждые 
1000 символов текста ($1.80 если вы 
не в США). 

Теіериііпв НоІІіпе, 
МоѵетЬег 14, 1991 
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Для того чтобы понять, нужно ли 
вам читать эту статью, проведем 
небольшой тест: когда вы в последний 
раз использовали оператор ѵіііиаі? Если 
ответ “никогда", то располагайтесь 
поудобнее и приступайте к чтению. 


Виртуальные функции! 
Это очень просто! 


Конечно, ваши программы могут превосходно рабо- 
тать и без оператора ѵігіиаі, и вам не обязательно по- 
нимать его смысл при работе с С++ или ТигЬо Разсаі. 
Однако без этого оператора нельзя в полном объеме 
использовать возможности объектно-ориентированного 
программирования (ООП), а особенно создания новых 
типов данных. 

В этой статье я хочу подвести вас к пониманию 
одной из ключевых особенностей ООП — использова- 
нию виртуальных функций — на примере одной ма- 
ленькой программы. Хотя программа написана на 
С++, вы можете получить такой же результат и на 
ТигЬо Разсаі. 

Основное различие между традиционными языками 
и ООП — возможность создавать принципиально но- 
вые типы данных. 

Каждый тип данных в ООП имеет свои внутренние 
характеристики (способ хранения информации, длину 
в байтах), а также определяет операции, которые 
можно выполнять над объектами этого типа. Напри- 
мер, в языке С число с плавающей точкой имеет по- 
рядок (показатель степени), мантиссу и бит знака; с 
ним можно производить различные арифметические 


действия (складывать, вычитать и т.п.). В ООП вы 
можете создать свои собственные типы данных, кото- 
рые будут обрабатываться так же, как и встроенные 
типы: компилятор будет выполнять контроль соответ- 
ствия типов, вы сможете создавать массивы новых ти- 
пов и т.д. Таким образом, добавляя свои собственные 
типы данных, вы фактически расширяете средство, на 
котором работаете. 

Какие же преимущества в таком расширении 
языка? С помощью ООП вы можете привести среду 
программирования в соответствие с условиями реша- 
емой задачи вместо того, чтобы приспосабливать по- 
становку задачи к имеющимся средствам программи- 
рования. Другими словами, предметная область непо- 
средственно отображается в область решения. Поэтому 
создавать и эксплуатировать большие и очень сложные 
программы в ООП становится намного легче и де- 
шевле: сокращаются сроки разработки программ и 
уменьшаются используемые ресурсы. 

В С++ новые типы данных являются расширением 
структур (зігисі), которые могут теперь содержать не 
только данные, но и функции. Переменная, заданная 
такой структурой, называется объектом. При этом 
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ВИРТУАЛЬНЫЕ ФУНКЦИИ? ЭТО ОЧЕНЬ ПРОСТО! 


каждая переменная-объект содержит свои, уникальные 
данные, а код функции, определенной в структуре, 
компилятор создает только один раз. Область действия 
такой функции ограничена элементами структуры, в 
которой эта функция определена. Компилятор С++ со- 
здает новый тип данных (с именем структуры) при 
помощи механизма, аналогичного ІуребеГ (Вы можете 
также использовать оператор сіазд, действующий по- 
добно 5ІгисІ, но обладающий некоторыми отличиями. 
Однако сейчас мы не будем на этом останавливаться.) 

В качестве примера рассмотрим текст программы 
РЕТ8.СРР, которая моделирует некий дом, полный 
домашних животных 1 . 

Прежде всего мы должны описать основной 
(родительский) тип данных, назовем его реі, который 
будет объединять в себе самое общее свойство домаш- 
них животных. Пусть общей характеристикой всех 
животных будет то, что они издают различные звуки 
(предположим, что рыбки издают очень тихие звуки) 2 : 

8ігисі ре! { 

ѵігПіаІ ѵоі(1 8реак() {} 

}; 

В структуре реі определена одна-единственная 
функция зреак. Эта функция не выполняет в данном 
случае никаких действий. Ее присутствие определяет 
одно из общих свойств домашних животных — по 
сути, функция просто объявляет: “Домашние живот- 
ные имеют свойство говорить (зреак)“. Для любого 
объекта типа ре! вы можете вызвать функцию зреак. 
Что же касается данных, общих для всех домашних 
животных, то в качестве таковых можно определить, 
например, возраст и название животного (іпі а§е и 
сЬаг *пате). 

Обратите внимание на то, что функция зреак опи- 
сывается в месте определения. Это так называемая 
іпііпе Птсііоп — встроенная (в код) функция. Такое 
определение похоже на макроопределение препроцес- 
сора — компилятор помещает в исполняемый код не 
заголовок вызова функции, а код реализации самой 
функции везде, где бы она ни вызывалась. Причем 
при вызове компилятор осуществляет полную проверку 
типа функции. Заметьте также, что в нашем случае 
тип реі не имеет конструктора — специальной фун- 
кции, выполняющей инициализацию объекта. На са- 
мом деле, если вы не помещаете конструктор явно, 
компилятор сам создает его и вызывает при размеще- 
нии объекта в памяти (важность этого станет более 
очевидной позднее). 

Как же теперь создать объекты различных живо- 
тных (собак, кошек, птиц и т.д.), которые бы могли 
издавать характерные для них звуки? Это можно сде- 
лать с помощью реализованного в языке механизма 

1 Ре! — ручное домашнее животное (англ.). 

2 То, какие именно общие свойства следует определить, ре- 

шает программист в соответствии с постановкой задачи. В са- 
мом деле, мы могли бы выбрать в качестве общего свойства 
проживание на планете Земля или то, что все животные 
имеют определенные геометрические размеры. 


наследования, указав базовый тип (ре!) при опреде- 
лении нового наследуемого типа (например, со- 
баки — ск>§): 

$!піс! сіоя : ре! { 

ѵоісі $реак() (ри!з( м Гав! а );} 

}; 

Каждый наследуемый тип может давать свое опре- 
деление функции зреак, которое будет наполнять вир- 
туальную функцию родительского типа конкретным 
содержанием. Например, приведенное выше мнемони- 
ческое определение можно перефразировать так: 
“Собака — это домашнее животное, которое говорит 
«Гав!»“. 

Хорошей проверкой правильности объектно-ориен- 
тированной программы может служить “проговарива- 
ние вслух“ написанного кода: если .получается осмыс- 
ленное утверждение — все в порядке! 

Попробуем теперь создать программу, описыва- 
ющую целый зверинец лающих, мяукающих и рыча- 
щих домашних животных. Для этой цели можно, на- 
пример, определить наш “зверинец“ 3 как массив ука- 
зателей на объекты типа ре!: 

ре! *тепа^егіе[] = {пеш (1о^, пеѵ са!, пеіѵ ЫгсІ}; 

Это определение очень простое, однако оно требует 
многих разъяснений. При создании такого массива на 
стандартном С вы должны сначала зарезервировать 
место для его элементов, а потом поочередно иници- 
ализировать эти элементы. В языке С++ ничего этого 
не требуется — компилятор инициализирует перемен- 
ные автоматически, для чего сам создает нужный код 
(число элементов массива в данном случае также 
определяется автоматически). Такая инициализация 
называется совокупной инициализацией (а§§ге§а!е 
іпіІіаПгаІіоп) — инициализация объекта в памяти (его 
динамическое размещение) с последующей инициали- 
зацией данных. Поскольку основную работу мы воз- 
ложили на компилятор, размер исходного текста про- 
граммы уменьшается, она становится более читабель- 
ной и мы в итоге делаем меньше ошибок. В стандарт- 
ном С тоже предусмотрены механизмы подобной ини- 
циализации (правда, в более примитивной форме), но 
при этом в списке инициализации могут быть только 
константы. В нашей же программе мы, вызывая опе- 
ратор пе>ѵ для динамического размещения объектов в 
памяти, фактически выполняем код, создающий эле- 
менты списка инициализации. Оператор пе\ѵ, подобно 
функции та11ос(), создает новый объект, резервируя 
под него место в оперативной памяти (а именно, в 
хипе — незанятом объеме памяти), и возвращает ука- 
затель на вновь созданный объект (размер резервиру- 
емой области определяется автоматически по типу 
объекта). Возвращаемый указатель автоматически 
включается в массив механизмом совокупной иници- 
ализации. 

Способ вычисления $2 (числа элементов массива) 
не нов — то же можно сделать и в стандартном С: 

3 Мепа^егіе — зверинец (англ.). 
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соп $1 іпі 82 = вігеоНшепа^егіе) / 8І2еоГ(тепа&егіе[0]); 

Этим только подтверждается факт, что массив 
шепа^егіе весьма похож на обычный массив указате- 
лей: вы можете добавить в него новый элемент просто 
расширением списка инициализации. Обратите все же 
внимание на то, что вычисление $2 осуществляется во 
время компиляции, а полученное значение включается 
прямо в генерируемый код, так что приведенная 
строка не вносит в программу дополнительных на- 
кладных расходов. В стандартном (АЫБІ) С оператор 
соп&( определяет переменную, значение которой ини- 
циализируется при ее создании и не изменяется в 
процессе работы программы (переменная доступна 
только для чтения). В С++ оператор соп$( работает 
аналогично директиве препроцессора #беНпе с той 
лишь разницей, что при обращении к переменной 
осуществляется проверка соответствия типов. 

Теперь, наконец, в функции таіп() вы можете за- 
ставить “говорить" всех “животных" “зверинца": 

ѵоігі таіп(ѵоісі) { 

*ог (іпі і = 0 ; і < 82; і + + ) 
тепадегіе [і] - > 8 реак О ; 

} 

Здесь функция зреак вызывается для каждого 
“животного" поочередно. В С++ на функции объекта 
ссылаются таким же образом, как на элементы данных 
в структурах языка С. Стрелкой (->) ссылаются на 
элемент через указатель 

тепадегіе [і] - > ареакО ; 
точкой — через сам объект 

Рі( 1 о. 8 реак 0 ; 

Замечу, в объектно-ориентированном программиро- 
вании не принято говорить “вызвать функцию 
$реак — свойство объекта Рісіо типа бо§“; говорят 
иначе — “послать сообщение $реак объекту Рісіо типа 
йо§“ (мы как бы просим объект Рісіо произвести дей- 
ствие; при этом способность осуществлять такие дей- 
ствия является свойством всех объектов типа бо&). 

Поскольку все “животные" могут “говорить" (это 
свойство определено в основном типе реі), то в этом 
отношении с ними всеми следует обращаться одина- 
ково. Это чрезвычайно удобно: вы можете заставить 
любой объект данного типа произвести указанное дей- 
ствие, не обращая внимания на конкретную реализа- 
цию действия. Программа становится значительно 
проще. Кроме того, вы легко можете добавлять в 
“зверинец" новые типы “животных" без какой-либо 
модификации ранее написанного кода. 

Какой зреак вызвать? 

Вот тут-то при более детальном размышлении и 
возникает проблема. Компилятору известно, что 
“зверинец" (тепа§егіе) — это массив указателей на 
“животных" (объекты типа реО. Когда вы посылаете 
сообщение 5 реак объекту типа реі, компилятор имеет 
информацию, достаточную только для того, чтобы 


произвести вызов функции базового типа, но ему не- 
известно, о каком унаследованном типе “животного" 
(собака, кошка и т.п.) идет речь. Как же тогда он 
определяет, какую именно функцию вызвать, получив 
сообщение $реак? 

Ответ заключается в понимании одного из основных 
принципов ООП — полиморфизма. В традицион- 
ном С вызов функций осуществляется с помощью так 
называемого механизма раннего или статического 
связывания. Компилятор генерирует код вызова кон- 
кретной функции (заранее известной) по ее имени, и 
этот вызов связывается с реализацией функции в про- 
цессе компоновки. При раннем связывании адрес вы- 
зываемой функции всегда известен во время компо- 
новки программы. Но механизм раннего связывания 
не всегда позволяет легко добавлять к имеющимся ти- 
пам данных новые наследуемые типы, использующие 
собственные реализации унаследованных функций. 
Дело в том, что если вы добавляете наследуемый тип 
данных, в котором переопределяются некоторые функ- 
ции, вы не можете использовать старый код про- 
граммы для их вызова. Ведь когда создавалась про- 
грамма, она еще “не знала" о том, что в дальнейшем 
появятся какие-то новые функции, к которым ей при- 
дется обращаться. И даже если при выполнении ка- 
ких-то действий с объектом нового типа программа по 
логике должна обратиться к переопределенной фун- 
кции унаследованного типа, все равно произойдет вы- 
зов функции базового типа, так как именно эта фун- 
кция жестко привязана к конкретному коду про- 
граммы. Поэтому при добавлении новых типов прихо- 
дится менять код программы, осуществляющий обра- 
щения к функциям, которые в этих новых типах пере- 
определены, и затем проводить повторную компиля- 
цию всей программы. 

Принцип полиморфизма (множественности обра- 
зов), реализованный в языке С -и-, предлагает гибкий 
механизм для решения означенной проблемы — позд- 
нее или динамическое связывание с использованием 
специальных функций, называемых виртуальными 
(ѵігіиаі). Механизм позднего связывания позволяет 
передавать сообщение о вызове виртуальной функции 
тому объекту, над которым выполняется действие. При 
этом виртуальная функция не связывается с объектом 
так, как это происходит с обычными функциями в 
процессе компиляции. Вы можете создать новый тип, 
унаследованный от базового, и написать для него дру- 
гую подходящую функцию с тем же именем, теми же 
формальными параметрами (сигнатурой функции) и 
типом возвращаемого значения, что и у виртуальной 
функции объекта базового типа. Затем вы можете 
скомпилировать свой код и скомпоновать его с уже го- 
товыми объектными (.ОВЛ файлами кода функций, 
обращающихся к виртуальным функциям объектов ба- 
зового типа 4 . Вызов необходимой функции (для объек- 


4 Заметьте, эти объектные файлы не требуют изменения и 
перекомпиляции. Таким образом, у вас появляется возмож- 
ность передавать или продавать свои собственные програм- 
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ВИРТУАЛЬНЫЕ ФУНКЦИИ? ЭТО ОЧЕНЬ ПРОСТО! 


1 . Без виртуальных функций 

зтгист соогсі { 
іпТ х, у; 
ѵоісі рг і пи ( ) ; 
ѵоісі зеКіпИ хх, іпТ уу) 

> ; 

соогсі *с = пеѵ»/ соогсі; — > 


с->ргіпТ(); // Компилятор вызывает 
// соогсі: :рг іпг( ) ; 


2. С виртуальными функциями 

зтгист соогсі { 
іпТ х, у; 

ѵігТиаІ ѵоісі ргіпТ(); 

ѵігТиаІ ѵоісі зеі: ( і п И хх , іпі: уу); 

> ; 

соогсі *с = пеѵѵ соогсі; 

Неявно добавляется 
компилятором 


с->рг іпТ( ) ; 

// Компилятор создает код, который: 
// а) получает ѴРТР ; 

//б) использует его для доступа 
// в ѴТАВІ_Е ; 

//в) по индексу находит в ѴТАВІ.Е 
// нужную функцию ; 

//г) вызывает эту функцию. 


соогсі : 

: рг іпт 

соогсі : 

: зеТ 


ѴТАВІ.Е 


X 

У 

ѴРТР 


X 

У 


тов базового или унаследованного типа) будет осу- 
ществляться уже в процессе выполнения программы и 
будет полностью зависеть от типа объекта, участву- 
ющего в вызове. Хочу еще раз подчеркнуть, что при 
позднем связывании адрес функции, соответствующей 
данному объекту, определяется во время выполнения 
программы. 

Хотя при знакомстве с объектно-ориентированным 
программированием в первую очередь на себя обра- 
щает внимание инкапсуляция, самое важное свойство 
ООП — возможность создавать новые типы данных. А 
работа с новыми типами данных невозможна без 
позднего связывания, реализуемого в языках С++ и 
ТигЬо Разсаі посредством виртуальных функций. 

Во время компиляции в С++ осуществляется про- 
верка того, что функция определена и аргументы и 
возвращаемое значение имеют верный тип. Однако в 
момент компиляции неизвестно, какой именно код бу- 
дет выполняться при вызове виртуальной функции. 
Поэтому на место реального вызова функции компи- 
лятор помещает в программу несколько специальных 


мные продукты, например, библиотеки классов, в виде объ- 
ектного кода и Ьеасіег-файлов с объявлениями типов. Этим 
вы сохраняете свои программные секреты, но не ограничива- 
ете возможности своих пользователей по наращиванию и 
дальнейшему развитию продукта. 


операторов. В процессе работы программы эти опера- 
торы извлекают указатель, используемый для вычис- 
ления адреса нужной функции, из самого объекта. По 
этому указателю, который в языке С++ называется 
ѴРТК (Ѵігіиаі РоіпТеК), а в ТигЬо Разсаі — ѴМТР 
(Ѵігіиаі МеІЬосі ТаЫе Роіпіег), из специальной таб- 
лицы выбирается физический адрес вызываемой про- 
цедуры. Эта таблица, называемая в С++ ѴТАВЬЕ 
(ѴМТ в ТигЬо Разсаі), содержит адреса всех вирту- 
альных функций. Каждый объект имеет свой указа- 
тель ѴРТК.. При вызове виртуальной функции сам 
объект определяет, какой код должен выполняться. 
Это станет более понятным, если вы изучите 
диаграмму. 

Обработка виртуальных 
функций компилятором 

Чтобы вычислить физический адрес функции, ме- 
ханизм позднего связывания выполняет дополнитель- 
ные, по сравнению с обычным, процедуры и поэтому 
работает немного медленнее. Некоторые языки ООП 
осуществляют только позднее связывание для всех 
процедур. Но при программировании на С++ и ТигЬо 
Разсаі у вас есть выбор: механизм позднего 

связывания включается явным указанием оператора 
ѵігіиаі; в противном случае используется стандартный 
вызов. Причем здесь действует еще одно правило. 
Если в базовом типе вы объявили функцию 
виртуальной и в наследуемом типе вы не 
переопределяете сигнатуру функции (формальные 
параметры) и тип возвращаемого значения, то в этом 
наследуемом типе такая функция считается 
виртуальной по умолчанию. Кстати, если вы решили 
переопределить виртуальную функцию в наследуемом 
типе, то вы не можете изменить один только тип 
возвращаемого значения. Нельзя определить две 
виртуальные функции с одинаковыми именами и 
сигнатурами, но с разными типами возвращаемых 
значений. Если же две функции с одинаковыми 
именами имеют разные аргументы, то эти функции 
тоже считаются разными, и механизм позднего связы- 
вания игнорируется. 

Каким же образом и когда инициализируется меха- 
низм позднего связывания — создается и заполняется 
таблица УТАВЬЕ, и в объектах устанавливается нуж- 
ный вход в нее? Эту работу выполняет конструктор 
объекта. В нашем примере, где конструктор не опре- 
делен, компилятор сам создает конструктор. В ТигЬо 
Разсаі вы должны явно создать и вызвать конструктор 
для инициализации указателя ѴМТ, в противном слу- 
чае при выполнении программы будет выдано сообще- 
ние об ошибке. В С++ конструктор автоматически вы- 
зывается при выполнении оператора пе\ѵ (С++ гаран- 
тирует, что конструктор будет вызван). 

Как известно, стандартный (АЫЗІ) С не имеет вир- 
туальных функций. Вы могли бы в какой-то мере смо- 
делировать их: определить зреак в типе реі как указа- 
тель на функцию, создать для каждого дочернего типа 
свою функцию $реак и в каждом объекте установить 
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указатель $реак на нужную функцию. Но это же 
масса работы! Как вы уже могли видеть, в С++ это де- 
лается намного проще и удобнее. 

А теперь немного разомнемся. Включите компью- 
тер, введите текст приведенной ниже программы и, 
используя встроенный отладчик среды или ТигЬо Ое- 
Ьи^ег, посмотрите, как она будет выполняться в по- 
шаговом режиме. Если вы захотите увидеть сгенериро- 
ванный код, то компилируйте программу с ключом -5 
в командной строке компилятора С++ фирмы Вогіапсі. 
Чтобы определить затраты на организацию виртуаль- 
ных функций, создайте цикл, осуществляющий боль- 
шое количество вызовов, и используйте ТигЬо РгоПІег. 
Потом удалите оператор ѵігіиаі и повторите тест. 

В качестве заключительного эксперимента убеди- 
тесь, насколько просто можно расширить программу. 
Добавьте в “зверинец" “животное" нового типа, ска- 
жем, лошадь (Ьогзе). Наиболее интересный эффект 
получится в случае, если создать для этого отдельный 
модуль, куда включить и код инициализации массива. 
Вы увидите, как программа управляет объектом, о 
существовании которого она ранее не подозревала. Я 
уверен, что выполнив все это самостоятельно, вы 
поймете, как работают виртуальные функции, и по 
достоинству оцените их. 

Б.Эккел 


// Текст программы РЕТЗ.СРР 
// Перекличка домашних животных 

#іпс1ис!е <зіс1іо.Н> 

зігисі реі { // базовый тип 

ѵіііиаі ѵоісі зреакО {} // определение функции 

}; 

зігисі СІ 08 : реі { // наследуемые типы 

ѵоісі зреакО {риіз( м Гав!“);} 

}; 

зігисі саі : реі { 

ѵоісі зреакО {риіз( и Мяу! и );} 

}; 

зігисі Ьігсі : реі { 

ѵоісі зреакО {риіз( м Чик-Чирик!);} 

}; 

зігисі доісШзН : реі { // доісШзН — золотая рыбка 

ѵоісі зреакО {риіз(“! и );} 

}; 

// Совокупная инициализация “зверинца 44 

реі *тепавегіе[] = { пе\ѵ сіо^, пеѵ/ саі, пеш Ьігсі }; 

сопзі іпі 82 = зігеоНтепавегіе) / зігеоГ(тепа^егіе[0]); 

ѵоісі таіп (ѵоісі) { 

Гог (іпі і = 0; і < зг; і + + ) 
тепавегіе[і] -> зреакО; 

> 


Куда мы направляемся 

С тех пор, как мы на- 
чали издавать наш бюлле- 
тень в 1988 году, редакция 
Теіериііп^ Ноіііпе постоянно 
задавала себе вопрос — 
“куда приведет нас вся эта 
технология?" 

Наш ответственный за 
распространение Ніго 

Шкапшга ответил на этот 
вопрос самым непосредст- 
венным образом. Лет 5 на- 
зад он был сфотографиро- 
ван в горах работающим на 
своем лэптоп-компьютере. 
Там не было воды, не было 
электричества, привязыва- 
ющих его к городу. Но там 
была телефонная линия. 
Сегодня она бы ему не по- 
надобилась. 

Проводные телефонные 
сети имеют большую про- 
пускную способность. Через 
них можно крутить теле- 
фильмы, передавать факс, 
звук, и видеосигнал однов- 
ременно или производить 


через них миллионы опера- 
ций в минуту. Это все про- 
сто прекрасно, если вы ра- 
ботаете в офисе. Но две 
трети американских рабо- 
чих там не работают. В 
других странах соотноше- 
ние еще хуже. 

Как быть с ними? 90-е 
годы ответят на это простой 
концепцией “компьютери- 
зации на выезде" (РіеШ 
Сотриііпя) . 

Миниатюрные компью- 
теры любых форм, разме- 
ров, с интерфейсами, удоб- 
ными конкретному пользо- 
вателю, будут связаны с 
компьютерными сетями без 
проводов и с минималь- 
ными затратами. Когда 
файл попадает в проводную 
сеть, он может быть чем 
угодно и делать что угодно. 
Не обязательно он будет 
письмом. Он может стать 
счетом, денежным перево- 
дом, заказом товаров или 
услуг. Не обязан он быть и 
“просто данными". Это 


может быть все что угод- 
но — изображение, оциф- 
рованный звук или фильм в 
виде “видеопочты". 

Люди, пестующие эту 
технологию, заработают в 
грядущем десятилетии 
большие деньги, производя 
больше, чем конкуренты, и 
с меньшими затратами. 
Они будут предоставлять 
лучшие услуги. “Компью- 
теризация на выезде" в 
90-х годах станет тем же, 
чем персональные машины 
стали для 80-х. 

Мы собираемся отслежи- 
вать эту технологию. С 
этого момента ТНе Теіериі- 
іщ$ Ноіііпе станет вашим 
источником информации о 
Ріеісі Сотриііп^. Следите за 
нами, учитесь у нас, сле- 
дуйте примерам и зараба- 
тывайте. 

ТНе Теіериііщ Ноіііпе , 
НоѵетЬег 7, 1991 


Частоты в восточной 
Германии свободны для 
мобильных сетей 

Советские войска выво- 
дятся из восточной Герма- 
нии, и Сегшап Випсіезрозі 
может использовать старые 
военные частоты для систем 
переносных телефонов 
РСМ. Планируется выдать 
третью лицензию на мо- 
бильную телефонию для 
использования этих новых 
частот. Две фирмы, кото- 
рые являются операторами 
в настоящее время, Мап- 
пезтап МоЬіІГипк апсі Вип- 
сіезрозі Теіесот, могут не 
быть допущены до соиска- 
ния, так как они недоста- 
точно быстро развивались в 
восточном направлении. 
Новая служба может начать 
работу к концу 1992 года, 
сообщили немецкие власти. 

ТНе Теіериііпв Ноіііпе , 
ИоѵетЬег 12, 1991 
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КОМПЬЮТЕРЫ САММИТ СИСТЕМС 



Сберечь глаза, сидя перед компьютером 

по 8 часов в день, - проблема. Саммит Системе 

- это идеальное разрешение ваших проблем! 




• Возможность преобразования САММИТ-286 в САММИТ-386/33 

• ЗирегѴСА монитор 1024x768, 256 цветов 

• Быстрый винчестер (17 мс; 105/52 Мб) 

• ОЗУ до 8 Мб (286) и до 32 Мб (386) 


• Местное обслуживание 

• Гарантия 2 года 


(095) 265-58 1 3, 26 1 -4407, 299- 1 1 62 
(0172) 973-1 19, факс: 973-519 


Поставьте Будущее Себе на Стол 



■тонн 


Вы хотите добиться успеха, применив в своем бизнесе новые информационные 
технологии? И Вы думаете, что Вам удастся осуществить это без ВИКТОРИИ? 

А Вы знаете о тех могущественных возможностях ВИКТОРИИ, обладателем 
которых можете стать ВЫ? Неужели Вы в состоянии от всего этого отказаться? 
Узнав, что у Вас есть ВИКТОРИЯ, Ваши конкуренты сдадутся без боя! 

ВИКТОРИЯ — это волшебная палочка в Ваших руках! 

Вы программист? Вы пользователь? Вы новичок? 

Новое компьютерное поколение выбирает ВИКТОРИЮ! 

Не упустите счастливый случай! 

Вам нравится Иогіоп Соттапдег? РСТооІз? ХТгее? 

Да ведь Вы еще не работали с ВИКТОРИЕЙ! 

ВИКТОРИЯ - это Ваша СИЛА 
ВИКТОРИЯ - это Ваше МОГУЩЕСТВО 
ВИКТОРИЯ - это Ваше ПРЕИМУЩЕСТВО 

Ваш ИНТЕЛЛЕКТ и Ваша ВИКТОРИЯ сделают Вас НЕПОБЕДИМЫМ! 


И Вы все еще сомневаетесь, какую оболочку Вам выбрать? 


ВИКТОРИЯ доступна всем! Мы поддерживаем предельно низкие цены! 
ВИКТОРИЯ — это атомная бомба в Вашем компьютере 


ВИКТОРИЯ - это новая 80РТ-Б0МБА! 

ВИКТОРИЯ — это ваша рабочая лошадка! 

У Вас есть ВИКТОРИЯ! Ваши конкуренты в панике! 


Работать с ВИКТОРИЕЙ — хороший тон для 
бизнесмена! 

Вы приобрели ВИКТОРИЮ! Победа у Вас в кармане! 


шлет пламенный ПРИВЕТ всем своим нынешним 
поклонникам ! 

говорит ДОБРО ПОЖАЛОВАТЬ своим будущим 
пользователям ! 

уже начала свое победное шествие по необъятным 
просторам одной шестой части суши. 


© 1991 СотриіегРгезз 
РЬопез: (095) 420-83-80 

(095) 491-01-53 
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РАЗРЕШИТЕ ПРЕДСТАВИТЬСЯ: МЗ-ЭОЗ 5.0! 



Появление новой операционной 
системы — всегда очень важное 
и знаменательное событие, которого 
с нетерпением ожидают не столько 
пользователи, сколько те, кто так 
или иначе причастен к компьютерной 
индустрии. 


Разрешите 
представиться: 
М5-РОЗ 5.0! 


Долгожданная 005 5.0, о вы- 
пуске которой сегодня пишет вся 
мировая компьютерная пресса, 
впервые поступила в продажу в 
июле 1991 года. Тогда же пришли 
первые сообщения о том, что 
фирмы 1ВМ и Согпрац приобрели 
право выпуска собственных 
модификаций Э05 5.0, а сотни 
фирм помельче уже получили 
права на выпуск этой операцион- 
ной системы по лицензии для по- 
ставки в составе своих компью- 
терных систем. Многие фирмы- 
производители прикладного про- 
граммного обеспечения откликну- 
лись выпуском своих новых про- 
дуктов, обеспечивающих работу в 
среде новой операционной си- 
стемы. Одними из первых были 
фирмы Зутапіес с сервисным па- 
кетом Ыогіоп ШіШіез 6.0 и Сепігаі 
Роіпі Зо^Цѵаге с конкурирующим 
пакетом РС Тооіз 7.0. Последняя 
фирма, кстати, передала МісгозоН 
свою программу восстановления 
стертых файлов, полная версия 
которой входит в пакет РС Тооіз 


7.0, получив в обмен право 
использовать в своем новом ин- 
струментальном пакете ин- 
терфейс, практически аналогич- 
ный оболочке М5-005 ЗНеІІ 5.0. 
Фирмы Ыоѵеіі и Вапуап Зузіетз 
сообщили, что их сетевое обеспе- 
чение также поддерживает М5- 
ООЗ 5.0. 

По сведениям, поступающим из 
московского представительства 
корпорации МісгозоН, завершена 
работа над русскоязычным испол- 
нением новой версии опера- 
ционной системы М5-005 5.0. В 
европейском отделении МісгозоН в 
Ирландии уже приступили к 
производству этого нового про- 
граммного продукта, в ближайшие 
месяцы он поступит в продажу в 
нашей стране. Оперативность Мі- 
сгозоН в изготовлении русскоязыч- 
ной версии может вселить на- 
дежду, что беспредел нашего пи- 
ратского копирования программ 
пока не остановил сизифовых уси- 
лий этой могущественной корпо- 
рации по приобщению нас к са- 


мой передовой высокотехноло- 
гической цивилизации и обеспече- 
нию отечественных пользователей 
русскоязычными версиями своих 
новейших программных продуктов. 
Однако долго ли продлится такая 
бескорыстная благотворитель- 
ность? Вовсе не нужно быть Но- 
страдамусом, дабы с уверенностью 
предсказать, что вечной она не 
будет. А тем временем в зару- 
бежную прессу уже проникают 
непроверенные сообщения, что 
МісгозоП не остановилась на 
достигнутом и уже на всех парах 
разрабатывает следующую версию 
МЗ-ООЗ (шестую?), которая 
якобы будет принципиально отли- 
чаться от нынешней версии 5.0 и 
будто бы будет поддерживать но- 
вую файловую систему НРР5 
(НІ&Н РеНогшапсе Рііе Зузіеш 
операционной системы 05/2), а 
также интерфейсы ЭРМІ Ф05 
Ргоіесіед Мобе ІпІегГасе, реализо- 
ванный в ЛѴіпсіолѵз 3.0 и в 05/2 
2.0) и ѴСР1 (Ѵігіиаі Сопігоі Рго- 
Вгат ІпІегГасе фирм РНаг Ьар и 
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(}иагІег<Іеск), а кроме того, будет 
работать в защищенном режиме. 

Подтвердятся ли эти слухи и 
доведется ли нам когда-то увидеть 
следующую русскоязычную версию 
М8-008 — покажет будущее. А 
сегодня русскоязычная версия М8- 
008 5.0, при создании которой 
была учтена справедливая кри- 
тика, прозвучавшая в адрес пре- 
дыдущей версии М8-008 4.01, на- 
конец-то, готова, и мы искренне 
приветствуем ее появление на 
просторах нашей чудесной ро- 
дины. 

Что же нового в 008 5.0? 
Кратко перечислить все неболь- 
шие изменения и улучшения едва 
ли возможно. В двух словах можно 
лишь сказать, что, хотя каких-то 
радикальных перемен не про- 
изошло, новая операционная си- 
стема стала гораздо более удобной, 
более безопасной и более комфор- 
табельной для пользователей-но- 
вичков. Некоторые “профи" мо- 
гут, не без некоторого цинизма, 
утверждать, что новая 008 утра- 
тила былое лидерство и плетется в 
хвосте тех технологических до- 
стижений, которые значительно 
раньше удалось реализовать дру- 
гим разработчикам программных 
продуктов. Однако в оправдание 
МісгозоН (разумеется, если де- 
ятельность МісгозоН вообще нуж- 
дается в какой-либо апологии) 
могу заметить, что любая новая 
версия 008 должна быть чуточку 
консервативной, отбирая и интег- 
рируя в себе лишь самые лучшие 
и нужные новшества и не бросаясь 
из стороны в сторону в погоне за 
яркими и блестящими безделуш- 
ками. Впрочем, уже то, что это 
новая операционная система, ко- 
торой наверняка суждено серьезно 
изменить технологию управления 
миллионами персональных ком- 
пьютеров, само по себе достаточно 
важная и злободневная новость. 
Поэтому лучше, наверное, все- 
таки начать с того, что в ней не 
изменилось, а соответствует на- 
шим привычным представлениям 
об операционной системе 008. 

В этой версии М8-008 в боль- 
шой степени сохранена преем- 
ственность с предыдущими верси- 


ями. Сохранилась прежняя таб- 
лица распределения файлов 
(РАТ). Имена каталогов по-преж- 
нему могут состоять из одиннад- 
цати символов А8СІІ, которые 
использовались в прошлом. Ко- 
мандная строка также может со- 
держать максимум 126 символов. 
Оставлен без изменений и преж- 
ний архаичный командный язык 
пакетных ВАТ-файлов, о якобы 
предстоящем радикальном изме- 
нении которого распространялось 
немало слухов. Не подтвердилось 
и то, что в новой версии М8Ф08 
будет заменен файл СОМ- 
МАЫО.СОМ по лицензии фирмы 
ТР. 8оПдѵаге, которая широко 
известна своим популярным паке- 
том зНагедѵаге- программ 4008, 
улучшающим и облегчающим ра- 
боту пользова- 


цессоре 8088, которые не имеют 
расширенной памяти). Ядро 008, 
для машин на процессоре 80286, 
может размещаться в области 
НМА (адреса выше 1 Мбайта) и, 
для машин на процессорах 80386 
или 80486 — в областях НМА и 
ІШВ, (адреса от 640 Кбайт до 
1 Мбайта), освобождая для 
использования прикладными про- 
граммами рабочее пространство до 
620 Кбайт. Именно это замеча- 
тельное свойство М8Ф08 5.0 

однозначно гарантирует новому 
программному продукту самое 
массовое признание и распро- 
странение во всем мире. Несо- 
мненно, дополнительное рабочее 
пространство памяти окажется 
очень кстати всем пользователям, 
которые используют такие 


теля в опера- 
ционной систе- 
ме 008. Ника- 
ких заметных 
изменений не 
претерпела в 
М8-008 5.0 и 
поддержка пос- 
ледовательных 
периферийных 
устройств, лен- 
точных накопи- 
телей, дисково- 
дов оптических 


Версия Максимальный объем 
М8-008 рабочей памяти 

Максимальный объем 
памяти при работе в сети 

3.3 

575 Кбайт 

490 Кбайт 

4.01 

565 Кбайт 

480 Кбайт 

5.0 

621 Кбайт 

613 Кбайт 


Эти цифры приводятся МІСГ 080 Й применительно к машинам 
на процессорах 386. В зависимости от конкретной 
конфигурации машины и используемого программного обес- 
печения возможны некоторые отклонения от указанных 
значений. 


дисков и прин- 
теров. Впрочем, новинка все же 
есть: теперь поддерживаются 

дисководы для 3,5“ флоппи-дисков 
емкостью 2,88 Мбайт. 

Одним из самых заметных по- 
ложительных изменений в М8- 
008 5.0 можно считать новый ме- 
тод размещения в памяти. Ядро 
новой 008, то есть внутренняя ре- 
зидентная часть операционной си- 
стемы, управляющая процессами 
работы остальной операционной 
системы и распределяющая для 
них физические ресурсы машины, 
заметно сокращено в размерах в 
сравнении с М8-008 4.01. От 
этого, впрочем, было бы мало 
проку, если бы не еще одно нов- 
шество, оказавшееся самым сенса- 
ционным: во всех современных 

машинах и во многих старых (за 
исключением тех машин на про- 


“жадные до памяти* 4 программы, 
как приложения для графической 
среды ХѴіпскпѵз 3.0, Ѵепіига РиЪ- 
НзЬег, РохРго и многие другие 
прикладные программные про- 
дукты. 

Кроме этого “памятного" мо- 
мента, есть и другая хорошая но- 
вость, касающаяся распределения 
ресурсов дополнительной памяти. 
В М8Ф08 5.0 включено средство 
ЕММ386.ЕХЕ, аналогичное извес- 
тной утилите (}ЕММ-386 фирмы 
(}иаг1егс1еск, позволяющее пользо- 
вателям машин с процессорами 
386 и 486 с помощью команд ОН 
ФЕѴІСЕНІСН) и Ш (ШАО- 
НІСН) убирать драйверы устрой- 
ств и резидентные программы из 
рабочей части оперативной памя- 
ти в “верхнюю" дополнительную 
ЕМ8-память. Так что, если вы еще 
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РАЗРЕШИТЕ ПРЕДСТАВИТЬСЯ: МЗ-ИОЗ 5.0! 


не успели обзавестись пакетом 
ОЕ5(Зѵіедѵ-386, в который входит 
замечательная утилита (}ЕММ- 
386, новая версия М5-005 5.0 
будет вашим пропуском в 
прекрасный новый мир самых 
высоких технологий управления 
памятью. Впрочем, похоже, 
использование столь изощренных 
постмодернистских технологий 
пока по карману лишь очень нем- 
ногим отечественным пользовате- 
лям персональных компьютеров. 

В оболочке ЭОЗ 5Ье11, которой 
практически пользовались лишь 
очень немногие владельцы преды- 
дущей МЗ-ООЗ 4.01, предпочитая 
более привычный ЫоИоп Сошшап- 
бег, произошли весьма существен- 
ные перемены. Создатели новой 
оболочки явно постарались учесть 
и ликвидировать прежние недо- 
статки, чтобы сделать работу в но- 
вой оболочке более комфортной и 
приятной. Новая 005 5Не11 может 
работать как в текстовом, так и в 
графическом режиме, а ее 
пользовательский интерфейс явно 
испытал облагораживающее вли- 
яние >Ѵіпскпѵ5. Вначале может по- 
казаться, что новая оболочка фун- 
кционально весьма похожа на 
многочисленные программные 
продукты других фирм, вы- 
полняющих привычный круг задач 
по управлению файлами: про- 

смотр иерархической структуры 
дерева каталогов и содержимого 
текстовых файлов, копирование, 
удаление и перемещение файлов с 
помощью мышки. Однако дальше 
начинаются различия: управление 
программами в новой Э05 5Ье11 
аналогично принципам, использу- 
емым в Шіпсклѵз и в Ргезепіайоп 
Мапа^ег 05/2. Вы можете не про- 
дираться сквозь раскидистое де- 
рево каталогов, а оперировать 
лишь ограниченной группой необ- 
ходимых прикладных программ. 
Несомненно, для большинства ря- 
довых пользователей такое управ- 
ление программами интуитивно 
более понятно и просто, чем осво- 
ение иерархической древовидной 
структуры хранения файлов на 
жестком и других дисках. 

Появилась в новой оболочке и 
модная ныне возможность осу- 


ществления многозадачного ре- 
жима работы: так называемый пе- 
реключатель задач (Тазк 5\ѵар- 
рег — в англоязычной версии 005 
5.0) позволяет пользователю обо- 
лочки 005 5.0 мгновенно перек- 
лючаться из одной прикладной 
программы в другую, например, 
переходить из Ьоіиз 1-2-3 в М5 
\Ѵоіч1 или в 6ВА5Е. Очень ве- 
роятно, что здесь компьютерные 
“профи“ наверняка снобистски за- 
протестуют: в М5-005 5.0 нет ни- 
какой подлинной многозадачности 


и эти уловки рассчитаны на 
наивных простаков. Дей- 
ствительно, в отличие, скажем, от 
ОЕ5(}ѵіе^, переключение задач в 
оболочке М5-005 5.0 основыва- 
ется на переключении не в опера- 
тивной памяти, а только на диске. 
Переключатель задач лишь симу- 
лирует многозадачность, хотя ни- 
какого одновременного выполне- 
ния задач на самом деле не про- 
исходит. Поэтому с помощью та- 
кой псевдомногозадачности нельзя, 
скажем, одновременно выполняя 


сіетоз/* 


йетоз/* готов поставить: 

■ Модемы Різсоѵегу 2400СМ/Э. Коррекция 
ошибок и компрессия данных (МЫР-5), Ѵ22Ьі$, 
2400/4800 Ьр$, адаптация под отечественные линии, 
сертификат Минсвязи СССР, годовая гарантия, 
поставки со склада. 

■ Компьютеры, лазерные принтеры, плотеры и др. 
оборудование фирмы НеѵѵІеН Раскате! (скидка до 
38%, СКВ). Гарантийное обслуживание 3 года. 

■ Портативные компьютеры ЫоіеЬоок 3865Х (СКВ). 

■ Восьмиканальные мультиплексоры портов типа 
Р5232 для ІВМ РС/АТ. Полная поддержка $СО 
Хепіх и М5 [305. 

■ Кассеты- эммуляторы языка Ро$і$сгірі для 
лазерных принтеров семейства І_а$ег.ІеЕ 

■ Программно загружаемые шрифты и кассеты с 
русскими шрифтами для лазерных принтеров НР 
1_а5ег.Іеі, Сапоп 1_ВР и совместимых с ними. 

■ Платы сетевых адаптеров - Агспеі, ЕіЬегпеі. 

■ Вычислительные сети на базе 05 МоѵеІІ под ключ, 
с последующей гарантийной и постгарантийной 
поддержкой. Обеспечение документацией по 05 
ЫоѵеІІ на русском языке. Возможно подключение 
локальных сетей к электронной почте Реісот. 

■ Системы на базе аппаратной русификации 
принтеров, терминалов, видеоадаптеров. 

вето*/*: 113035 Москва 
Овчинниковская наб. дом 6/1 
Тел.: 231-21-29; 231-63-95 
Рах: (095) 233.5016; 

Е-таіІ: іп[о@І^.сІето5.5и 
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две программы, “вырезать* 4 кусок 
изображения из одной прикладной 
программы и “вклеить** его в дру- 
гую, как это возможно с помощью 
ЭЕ8(}ѵіе\ѵ, 8оГйѵаге Сагоизеі или 
АѴіпсіоѵз. Однако, можно предпо- 
ложить, что большинству пользо- 
вателей 008 настоящая многоза- 
дачность на самом деле не очень- 
то и нужна, тогда как реали- 
зованная в М8-008 5.0 рудимен- 
тарная псевдомногозадачность на- 
верняка окажется удобной, полез- 
ной и продуктивной для многих 
неискушенных конечных пользо- 
вателей. А профессионалы навер- 
няка смогут использовать для ре- 
ализации подлинной многозадач- 
ности другие программные сред- 
ства. 

Команды 008 также подверг- 
лись достаточно заметным изме- 
нениям. Появились некоторые но- 
вые команды, пополнился синтак- 
сис многих старых команд. По- 
мимо того, что в оболочке 008 
имеется удобная справочная си- 
стема, теперь и любая внешняя 
или внутренняя команда отклика- 
ется на аргумент /? в своем син- 
таксисе, выводя на экран краткое 
описание. Многим, наверное, при- 
ходилось видеть приклеенные на 
мониторе бумажки, которые слу- 
жат шпаргалками забывчивым 
пользователям и на которых не- 
редко записывается синтаксис та- 
ких команд, как РСЖМАТ или 
РКШТ. Отныне для эффективной 
работы со всеми командами И08 
совершенно не нужно листать 
справочное руководство: ответы на 
любые вопросы всегда под рукой. 
Разумеется, такое замечательное 
справочное новшество 008 можно 
только приветствовать, лишь 
удивляясь задним числом, почему 
же этого не было сделано раньше? 

Команда РСЖМАТ с аргументом 
/Я теперь позволяет осуществлять 
быстрое форматирование дисков, 
которые ранее уже были отформа- 
тированы. Быстрое форматирова- 
ние обнуляет таблицу распределе- 
ния файлов и каталог, но данные 
при этом остаются не тронутыми. 
Это, во-первых, позволяет заметно 
экономить время при переформа- 
тировании дисков, которые нахо- 


дятся в хорошем состоянии, а, во- 
вторых, если пространство на 
диске позволяет, таблица РАТ и 
корневой каталог сохраняется где- 
нибудь на диске, чтобы с по- 
мощью команды И N РСЖМАТ вы 
смогли бы вновь при необходимо- 
сти восстановить утраченную 
структуру. Более полная утилита 
ИЫРСЖМАТ входит в пакет РС 
Тооіз 7.0, а в новой версии 008 
она появилась по лицензии, 
предоставленной МісгозоН фирмой 
Сепігаі Роіпі 8оК\ѵаге. 

Другая новинка, с которой 
также уже должны быть знакомы 
пользователи последних версий 
пакетов РС Тооіз и ЫоПоп Шііі- 
Ііез — это резидентная программа 
МЖКХЖ, предназначенная для 
улучшения условий безопасной со- 
хранности данных на дисках. В 
специальном защищенном файле 
МІККСЖ.РІЬ постоянно отслежи- 
вается и сохраняется текущая 
файловая структура диска. Этот 
файл всегда присутствует в корне- 
вом каталоге жесткого диска и пе- 
реписывается при каждой переза- 
грузке компьютера, а его преды- 
дущая резервная копия сохраня- 
ется в файле МЖКСЖ.ВАК. Если 
в АІІТОЕХЕС.ВАТ указана ко- 
манда МЖКХЖ С:, в файле МЖ- 
КОК.РІБ сохраняется копия РАТ 
диска С:. Но можно сохранить в 
МЖКОК.РІЬ также отраженные 
образы и других дисков, указав их 
поименно. Например, так: 

МІРРОР С: й: Е: 

Программа МЖКОК может ра- 
ботать резидентно, постоянно 
отслеживая уничтожение файлов. 
Для этого достаточно выполнить 
команду МЖКОК с аргументом 
/X. Файл МЖКОК. РІЬ может быть 
затем использован сопутствующей 
утилитой ІІНОЕЬЕТЕ для восста- 
новления уничтоженных файлов, 
разумеется, если их место на 
диске не было уже использовано 
для записи других файлов. В 
отличие от ранних версий утилит 
типа ІІпЕгазе из Ыог1оп ШіШіез, с 
помощью ІІНОЕЬЕТЕ и МЖКОК 
нет нужды вспоминать и под- 
ставлять стертую первую букву в 
восстанавливаемом имени файла, 
так как файловая структура пол- 


ностью отражается в МЖКОК. РІЬ. 
Точно так же с помощью упомя- 
нутой ранее утилиты ІЖРОКМАТ 
с диска читается скрытый файл 
МЖКОК. РІЦ если применялось 
быстрое форматирование по ко- 
манде РОКМАТ с аргументом /% 
и поэтому все случайно уничто- 
женные при форматировании дис- 
кет данные могут быть затем 
успешно восстановлены. А если 
МЖКОК запускается с аргументом 
/рагіп, по которому сохраняется 
структура разбиения жесткого 
диска, с помощью утилиты ІІЫ- 
РОКМАТ можно выкарабкаться из 
гораздо более серьезной пере- 
делки. 

Во многих популярных утили- 
тах и оболочках, применяемых се- 
годня пользователями персональ- 
ных компьютеров, есть возмож- 
ность просматривать содержание 
диска или каталога, подбирая 
файлы по определенным парамет- 
рам. Утилита О Ж новой версии 
008 может теперь воспроизводить 
на экране еще и перечень файлов, 
которые включаются в список или 
исключаются из него по желатель- 
ным параметрам, а также сорти- 
ровать файлы по имени, расшире- 
нию, размеру или дате. Между 
прочим, имена файлов теперь вос- 
производятся ЭЖ не заглавными, 
а строчными буквами. 

Кроме того, многие утилиты и 
оболочки, например Ыогіоп Согп- 
тапбег, позволяют восстанавли- 
вать “историю** введенных команд 
и выполнять простые макроко- 
манды. Наконец-то, и 008 имеет 
такую возможность. Маленькая ре- 
зидентная сервисная программа 
008КЕУ, впервые появившаяся в 
008 5.0 и занимающая в памяти 
всего 4 Кбайта, позволяет вывести 
из буфера памяти на экран список 
ранее введенных команд. Доста- 
точно нажать функциональную 
клавишу Р7, и вы получите на эк- 
ране перечень всех команд, вы- 
полненных после включения ком- 
пьютера. Используя клавиши 
управления курсором, можно за- 
тем выбрать нужную команду, ча- 
стично отредактировать ее и вы- 
полнить снова. С помощью этой 
утилиты можно также выполнять 
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РАЗРЕШИТЕ ПРЕДСТАВИТЬСЯ: МЗ-ООЗ 5.0! 


макрокоманды с различными 
изменяемыми параметрами по на- 
жатию установленных клавиш. 
Имеется возможность присваивать 
макрокомандам любые удобные 
для запоминания названия, объе- 
динять их в цепочки, используя в 
качестве разделителя макрокоманд 
два символа — $Т. Например, 

если вы хотите, чтобы по макро- 
команде ДИСК форматировалась, 
а затем проверялась дискета в 
дисководе А:, можно написать та- 
кую макрокоманду: 

005КЕУ ДИСК=Р0КМАТ А: $Т 
СНКЭЗК А: 

Разумеется, допустимо писать 
не только заглавными, но и строч- 
ными буквами. Для более сложных 
макрокоманд в синтаксисе 
ЭОЗКЕѴ могут применяться па- 
кетные параметры $1-$9, которые 
эквивалентны фиктивным пара- 
метрам %1-%9 в командных па- 
кетных файлах. Например, если в 
вашем компьютере два дисковода 
для гибких дисков, предыдущую 
макрокоманду можно сделать бо- 
лее удобной, если написать: 

005КЕѴ ДИСК=Р0РМАТ $1 $Т 
СНКОЗК $1 

Если вам теперь понадобится 
отформатировать и проверить дис- 
кету в дисководе В:, достаточно 
написать в командной строке 
ДИСК В: и нажать клавишу Епіег. 
А проявив еще немножко фанта- 
зии, можно создать гораздо более 
сложные и изощренные макроко- 
манды, которые значительно 
облегчат жизнь за клавиатурой 
компьютера. 

Еще одна радостная новость: 
давным-давно морально устарев- 
ший строчный редактор текстов 
ЕЭиЫ наконец-то ушел на покой. 
Место этого ’ музейного экспоната 
теперь занял новый и вполне со- 
временный полноэкранный тексто- 
вый редактор ЕЭІТ — наверняка 
он многим придется по вкусу. 
Причем ЕЭІТ.СОМ просто-напро- 
сто запускает текстовый редактор 
в файле (}ВА5ІС.ЕХЕ, который 
жеет непосредственное проис- 
хождение от известного <ЗиіскВА- 
5ІС. И еще новость: (}ВА5ІС за- 
менил в 008 5.0 ушедший в 
отставку старый СЛѴ-ВАЗІС. 


Впрочем, присутствие (}ВА- 
ЗІС.ЕХЕ — скорее ловкий 
рекламный трюк; он отнюдь не 
заменяет настоящий (ЗиіскВАЗІС, 
хотя и имеет аналогичную гипер- 
текстовую справочную систему, 
отладчик и такие же приемы ре- 
дактирования, но компилирует 
только в памяти. Впрочем, пре- 
восходный текстовый редактор 
(ЗВАЗІС, который, кстати, удобно 
управляется мышкой, сполна 
оправдывает введение в П05 5.0 
этой демонстрационной про- 
граммы. 

МЗ-ЭОЗ 5.0 поддерживает го- 
раздо большее по объему прямое 
разбиение внешних накопителей: 
до 2 Гбайт вместо прежних 
32 Мбайт. А пользователям особых 
разбиений диска, осуществляемых 
программами Оізк Мапа^ег и 
ЗреесІЗіог, теперь предоставляется 
новая версия драйверов ОМ- 
ОКѴК.ВШ и 88ТОК..5Ѵ8. С новой 
операционной системой могут 
использоваться прежние сетевые 
драйверы, но имеется и новый на- 
бор сетевых драйверов. Новое, 
полностью переработанное, руко- 
водство пользователя подробно 
объясняет приемы оптимальной 
настройки системы, а в текстовых 
файлах К.ЕАЭМЕ содержится 
дополнительная информация о 
способах преодоления возможных 
проблем аппаратной и програм- 
мной несовместимости. Новая вер- 
сия ЭОЗ 5.0 предназначена для 
любых персональных компьютеров 
с процессорами от 8088 до 486, с 
объемом оперативной памяти не 
менее 512 Кбайт, и при установке 
на жестком диске занимает 
2.8 Мбайта. 

Выпуск новой версии МЗ- 
БОЗ — очень сложная и трудная 
задача. В процессе создания новой 
версии корпорация МісгозоН более 
года работала в тесном контакте с 
семью тысячами пользователей и 
дистрибьюторов программных про- 
дуктов, чтобы “выловить всех 
блох 44 и в дальнейшем обеспечить 
всему миру быстрый безболезнен- 
ный переход на новую операцион- 
ную систему. Испытательные 
бета-версии М8-Э08 5.0 были 

известны многим отечественным 


специалистам уже с конца 
1990 года. Похоже, что эти усилия 
не пропали даром. Все, кому часто 
приходится иметь дело с установ- 
кой операционных систем на но- 
вые машины, ОЕМ (Огі^іпаі 
Е^иіртеп^ МапиГасІигег — изгото- 
вители комплексного оборудова- 
ния, укомплектованного компо- 
нентами, изготовленными другими 
фирмами), многочисленные кон- 
сультанты, эксперты и специали- 
сты скоро смогут увидеть и испы- 
тать конечный результат этих тру- 
дов. Нет сомнения, что новая вер- 
сия 003 немедленно превратится 
в фактический стандарт, с кото- 
рым должны будут считаться все, 
вовлеченные в компьютерную ин- 
дустрию. 

По сведениям, полученным от 
московского представительства Мі- 
сгозоН, в первую очередь доступ к 
новой операционной системе по- 
лучат отечественные ОЕМ, кото- 
рым будут предоставляться лицен- 
зии на производство русской М5- 
ЭОЗ 5.0 для комплектации 
выпускаемых ими персональных 
компьютеров. Однако русско- 
язычная МЗ-ООЗ 5.0 будет прода- 
ваться и отдельным пакетом для 
всех желающих, что обычно не 
практикуется в других странах. 
Ориентировочная цена пакета М5- 
003 5.0 будет составлять 
100 долларов или 180 немецких 
марок. Наверняка, такой пакет 
можно будет купить и за соответ- 
ствующее количество рублей. А 
сегодня МісгозоН уже уведомляет 
своих дистрибьюторов о распро- 
даже залежалых пакетов М5- 
003 4.01, которые спешно рас- 
продаются всего лишь за 90-95 
марок. МісгозоГі также предлагает 
комплектный вариант распродажи 
МЗ-ООЗ 4.01 вместе с русско- 
язычной версией М3 ^огкз 2.0 за 
210 немецких марок, тогда как 
рекомендованная базовая цена 
одного лишь пакета М3 >Ѵогкз 2.0 
первоначально составляла в 295 
немецких марок. 

А.Петроченков 

214000, Смоленск, а/я 44 
Телефон: (08100) 5-58-05 
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Что же новенького приготовил нам 
дядюшка Билл со своей компанией 
суперразработчиков? Вам интересно? 
Признаемся по секрету — нам тоже. 
Итак, вдоволь налюбовавшись пейзажем 
за тремя парадными окнами, попробуем 
заглянуть в то новое маленькое окошко, 
которое, хотя еще и прикрыто от 
любопытных взглядов, но уже вот-вот 
откроется. Давайте подойдем к нему 
потихоньку и заглянем в мир Шпйот... 


>ѴІГІСІОѴѴ5 3.1 

Что новенького? 


Предлагаемая здесь информация об МЗ-\Ѵіп<Іо\ѵ5 3.1 
собрана из многочисленных журнальных статей, ново- 
стей ИЗБИЕТ и дополнена или проверена автором на 
первой бета-версии продукта (май 1991 года). 

При создании новой версии ^ѴіпПодѵз 3.1 фирма Мі- 
сгозоН выделила следующие направления функци- 
онального развития продукта: 

- увеличение производительности; 

- устойчивость к сбоям системы и прикладных прог- 
рамм; 

- включение технологии ТгиеТуре масштабируемых 
фонтов; 

- увеличение интеграции программ; 

- расширение системы для новых компьютерных плат- 
форм. 

Увеличение производительности 

Для увеличения производительности фирмой были 
предприняты следующие шаги. 

1. Улучшен процесс установки системы на диск. 
Теперь ЗЕТІІР различает и определяет большее коли- 
чество типов “железа", конфигураций и ТЗК.-ОВ, чем 
раньше, и позволяет пользователю почти не забо- 
титься на этот счет. Хотя для пользователя процесс 


установки не изменился и об этих улучшениях он мо- 
жет только догадываться. В моей версии продукта 
были и неприятные моменты: программа “зависала" 
при работе из МЗ-ЭОЗ 5.0 (не бета) в режиме 
ООЗ = ЕІМВ, список предложенных драйверов мыши и 
видеоадаптеров был весьма скуден по сравнению с 
\Ѵіпсктз 3.0а, но это мелочи. 

2. Полностью переписан РПе Мапа§ег, и, поверьте, 
сделано это превосходно. Интерфейс программы очень 
похож на РПе Мапа^ег в Ыогіоп Эезкіор и позволяет 
создавать отдельные окна с “деревом" и списком фай- 
лов в директории. При переходе в другую директорию 
новое окно не создается, а обновляется текущее и 
весьма быстро. РПе Мапа^ег может запомнить состо- 
яние своих окон и полностью его восстановить при 
следующем запуске программы. В меню ОрГюпз по- 
явилась настройка Роли для установки фонта, кото- 
рым идет отображение имен файлов и директорий, а 
форматирование дискеты может идти в режиме (}иіск 
Рогтаі. Есть еще одно объявленное, но, видимо, пока 
не реализованное свойство РПе Мапа^ег, касающееся 
более интуитивной модели манипулирования фай- 
лами. Например, для печати файла достаточно пере- 
местить иконку файла (Пга^ апН Пгор) из окна РПе 
Мапа^ег на иконку Ргіпі Мапа^ег. Пользователь будет 
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>ѴШОО\Ѵ$ 3.1. ЧТО НОВЕНЬКОГО? 


иметь возможность переместить иконку какого-нибудь 
файла на заголовок (Шіе Ьаг) работающей программы 
или на ее иконку, и этот файл будет загружен в про- 
грамму. После работы с Рііе Мапа^ег остается прочное 
желание постоянно его использовать. 

3. Рго^гат Мапа^ег не претерпел таких серьезных 
изменений, как Рііе Мапа^ег, хотя получил несколько 
долгожданных улучшений. Новая “обязательная" 
группа 8ТАКТ11Р запускает при загрузке Рго^гаш 
Мапа^ег включенные в нее программы (если Рго^гаш 
Мапа^ег работает как командный процессор — зНеІІ 
\Ѵіпбо\ѵ5). Строка описания программы в Рго^гат 
Мапа^ег (рго^гат Нет) автоматически делится на не- 
сколько строк. В команде Кип наконец-то появилась 
опция Ъго\ѵ$е, а опция сохранения состояния >Ѵіпс1ош5 
перекочевала в меню программы. 

4. Ргіпі Мапа&ег умеет теперь самостоятельно вос- 
станавливаться после сбоев и продолжать работу. На- 
пример, когда у вас кончается бумага, печать возоб- 
новляется автоматически после приведения принтера в 
состояние оп-Гше. Другим, еще не реализованным, 
улучшением будет появление универсального принтер- 
ного драйвера ШИШКУ), который позволит фир- 
мам — производителям принтеров очень просто и бы- 
стро описывать параметры своих принтеров, используя 
небольшую таблицу. Около 250 принтеров будут под- 
держиваться в >Ѵіп<іо\ѵ5 3.1 через универсальный драй- 
вер. 

5. В Сопігоі Рапеі изменению подверглась только 
настройка Ое$кІор. Во-первых, благодаря опции вы- 
равнивания заголовков (У/гар Шіе) имена программ 
под иконками могут выравниваться в две и более 
строки, не перекрываясь с именами других программ. 
Во-вторых, появился встроенный 8сгееп $аѵег с че- 
тырьмя модулями вариантов эффектов с разнообраз- 
ной настройкой и опцией пароля. 

6. Улучшена поддержка сети. Проблемы, возника- 
ющие при работе с сетью, легче определять и решать 
с помощью расширенной диагностики типа и источ- 
ника проблемы. Другим важным изменением будет 
предоставленная пользователю возможность опреде- 
лить “постоянное" (рег$і$1епО соединение. При этом 
информация об удаленном принтере или диске сохра- 
нится в среде \Ѵіпс1о>ѵ5 после окончания сессии. Любое 
такое неподсоединенное устройство будет высвечи- 
ваться как недоступное в Рііе Мапа^ег. Для возобнов- 
ления соединения пользователю достаточно просто 
нажать на иконку диска мышью. 

7. Улучшение производительности системы видно 
на глаз (не на самых мощных компьютерах). Увели- 
чены производительность драйвера дисплея, скорость 
печати. Реализован быстрый страничный обмен 
(ра^іп^) в 386 расширенном (епНапсеё) режиме. Про- 
граммы, вызывающие команду печати, быстрее полу- 
чают обратно контроль для продолжения нормальной 
работы. Система будет включать в себя Ра$Ші$к — 
32-разрядный драйвер, позволяющий У^іпсіоѵѵз в обход 
ПОЗ обратиться к В108 для страничного обмена 
(ра^іп^) с файлом виртуальной памяти. 


8. Пара слов об общем дизайне системы. Радуют 
глаз 3-0 эффекты и приятная палитра элементов окна 
(особенно синий цвет в Шіе Ьаг). Выделение тексто- 
вого блока в диалоге (сііаіоя Ьох) и меню теперь про- 
исходит не черным, а голубым цветом (сІе^аиИ). 

Устойчивость к сбоям системы 
и прикладных программ 

После выхода в свет в мае 1990 года версии ^Ѵіп- 
ёо\ѵ8 3.0 фирма МісгозоН в октябре 1990 года выпу- 
стила единственную обновленную версию АѴіп- 
склѵз 3.0а, в которой устранила ряд незначительных 
ошибок. Обо всех остальных “темных" моментах из 
жизни >Уіп(іоіѵ5, заканчивавшихся сухим 
“ІІпгесоѵегаЫе Арріісаііоп Еггогз" ШАЕз), предлага- 
лось гадать самому пользователю или звонить в Мі- 
сгозоН Ргосіисі Зиррогі Зегѵісез. Эта служба поднато- 
рела в решении многих вопросов, связанных с конфи- 
гурацией операционной системы и >Ѵіп<1оіѵз, совме- 
стимостью ТЗК-ов и драйверов и т.д. Естественно, что 
всех проблем версия 3.0а не решила, поэтому в ^іп- 
сіо^ѵз 3.1 был сделан упор на следующие направления: 

- улучшение диагностики события, вызвавшего 
ошибку; 

- создание специальных средств в помощь разработчи- 
кам для написания программ, лишенных ошибок; 

- изящное управление ошибкой в прикладной про- 
грамме (ошибка не влечет за собой крах системы). 

1. Диагностика ошибок сейчас происходит следу- 

ющим образом: появляется сообщение о том, что 
ошибка случилась в такой-то программе, в таком-то 
модуле, по такому-то смещению. Такая диагностика 
действительно сильно упрощает процесс устранения 
ошибки. Дополнительно к этому версия 3.1 будет про- 
даваться с программой ‘Шг. >Ѵа1зоп“, которая записы- 
вает информацию о случившейся ошибке. Данные 
этой программы помогут сделать “откат" от 

ошибки — проследить причины ее возникновения — а 
затем выявить и устранить ее. 

2. К версии 3.1 фирма МісгозоН выпустит средство 
для разработки надежных программ, устойчивых к 
ошибкам. Например, в систему будет включен новый 
механизм, позволяющий проверять многие параметры, 
через которые прикладная программа “общается" со 
средой \Ѵіпс1о>ѵ5. Если программа использует непра- 
вильный тип параметров или их величина выходит за 
допустимый диапазон, то будет выдано сообщение об 
ошибке. В средства разработки будут включены неко- 
торые новые утилиты определения источника про- 
блемы. Например, новый “стресс тест" создает высот 
коактивную и динамичную среду, в которой ошибки 
разрабатываемой программы буквально “посыпятся" 
на программиста. 

3. Если выполнение прикладной программы закон- 
чилось “зависанием", пользователь может воспользо- 
ваться клавишами СігІ+АИ+ОеІ, и \Ѵіпс1о\ѵз задаст во- 
прос о продолжении или прекращении выполнения 
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программы. Если пользователь ответит “прекратить* 4 , 
то прикладная программа завершится, >Ѵіпс1о^ѵ5 пере- 
установит среду в стабильное состояние, что позволит 
продолжать нормальную работу других программ без 
перезагрузки всей среды >Ѵіпс1о>ѵз. 

Технология ТгиеТуре 
масштабируемых фонтов 

В \Ѵіпс1о\ѵ5 3.1 включена новая технология масшта- 
бируемых фонтов ТгиеТуре. Она поддерживает кон- 
турное (оиіііпе) изображение фонтов и позволяет 
пользователю получать фонты любого размера. 
Обеспечивается высококачественный вывод на любой 
монитор или принтер, поддерживаемый ХѴіпсІо^ѵз. 

ТгиеТуре-технология является составной частью 
>Ѵіпс1оаѵз 3.1. Пользователю не нужно ее дополнитель- 
но покупать или устанавливать, и любая программа 
может воспользоваться этими фонтами. В версию 3.1 
будет включено четыре семейства Оатііу) фонтов 
технологии ТгиеТуре: Агіаі (как альтернатива 

Неіѵеііса), Тітез Ыеш Котап, Соигіег и 5утЪо1. 

Так как технология ТгиеТуре перенесена в >Ѵіп(1одѵз 
из Арріе МасіпІозН, МісгозоН позаботилась о том, что- 
бы фонты этой технологии могли без каких-либо из- 
менений использоваться и в ЛѴіпсІолѵз, и на МасіпІозН. 

Фонты ТгиеТуре автоматически конвертируются в 
растровое изображение (Ьіітар іша^ез) и загружаются 
в лазерный принтер. На экране пользователь видит то 
же самое, что и на распечатанной странице. ТгиеТуре 
использует динамическую загрузку фонтов в принтер, 
посылая не все символы, а только требующиеся, что 
повышает скорость и эффективность печати. 

Несколько слов о вставших передо мной проблемах 
при использовании ТгиеТуре-фонтов. Во-первых, каж- 
дый тип фонта (ге^иіаг, Ьоісі, ііаііс, ЬоИ ііаііс) имеет 
размер около 56 Кбайт, и загрузка фонтов в память 
обходится не дешево (по отношению к памяти). 
Во-вторых, \Ѵогё Гог ХѴіпсіоаѵз, настроенный на 
Ьазег Леі ШР (т.е. использующий принтерные фонты), 
не распознал и не вывел в список ни одного фонта 
ТгиеТуре. Хотя, если написать имя фонта вручную, 
все будет корректно работать вплоть до того момента, 
как вы захотите восстановить запомненный документ, 
оформленный фонтами ТгиеТуре. Я получил чистый 
лист на экране и периодическое “зависание** машины. 
В-третьих, были проблемы с русификацией, связанные 
с тем, что фонт Соигіег теперь ТгиеТуре, а Неіѵеііса и 
Тітез Котап вообще отсутствуют. Мне пришлось 
отказаться от Соигіег Сугііііс и 5та11 (еще один новый 
фонт ргеѵіедѵ из >ѴТЛѴ или Ехсеі). 

Увеличение интеграции программ 

1. Технология связи и внедрения объектов (О^есі 
Ьіпкіпв апсі ЕшЪесісІіпЕ). 

Эта технология создает среду, в которой прикладная 
программа может различать (зЬаге) информацию об 
отдельных “кусках** своей среды. Через технологию 


ОБЕ данные в зависимости от типа разделяются на 
объекты. Таблица, график (сНагО электронной таб- 
лицы, параграф текста — все это примеры таких объ- 
ектов. ОБЕ обеспечивает возможность программам 
различать эти объекты очень легко. 

Среда >Ѵіпбо\ѵ5 3.1 поддерживает ОБЕ посредством 
стандартной библиотеки, интерфейса и протокола об- 
мена объектами данных. Разработчики в среде >Ѵіп- 
(1о\ѵ5 будут включать свойства ОБЕ в программы, и 
пользователи получат новый уровень интеграции про- 
грамм. 

Свойства ОБЕ сейчас включены в новые версии 
программ АѴіпёоѵѵз ЛѴгііе, РаіпіЬгизН и СагсШІе. Поль- 
зователь может, например, создать картинку в Раіпі- 
ЬгизН и перенести ее в СагсШІе. Для исправления кар- 
тинки достаточно два раза нажать на нее мышью 
(боиЫе сііск). При этом автоматически загрузится 
РаіпіЪгизН с картинкой. Вместо команды 8аѵе в Раіпі- 
ЬгизЬ появится команда ИрсШе, завершающая процесс 
вносимых изменений. Посредством технологии ОБЕ 
пользователь получит высокоинтегрированную среду, 
где множество программ будут общедоступными инст- 
рументами для создания всевозможных объектов. 

Правда, есть здесь некоторые “подводные камни**: 
например, размер картинки, загруженной в РаіпіЬгизЬ 
из СагсШІе, изменять уже нельзя. Впрочем, этого и 
следовало ожидать. В СагсШІе также с успехом загру- 
жается таблица Ехсеі 3.0 (в котором, кстати, протокол 
ОБЕ реализован для внутренних целей) и с той же 
проблемой неизменяемости размера объекта. Тем не 
менее, технология ОБЕ — одно из самых важных 
улучшений среды >ѴіпсІо^ѵ5. 

2. Улучшение поддержки динамического обмена 
данными Шіпатіс Оаіа ЕхсНап^е). 

ООЕ является стандартным средством среды ЛѴіпсІо- 
ѵз для разделения (зЬаге) данных между программа- 
ми. В версии 3.1 реализована новая Библиотека Упра- 
вления Динамическим Обменом Данными ФОЕМЬ — 
ООЕ Мапа^ег УЬгагу), которая предлагает высокоуро- 
вневую модель программирования и упрощает процесс 
разработки свойств ООЕ в программах для ^іпс!о\ѵз. 

3. Улучшение поддержки ЭОЗ-программ. 

Производительность 005-программ увеличена, осо- 
бенно когда ^Ѵіпсіоѵз 3.1 работает вместе с 
М5Ф05 5.0 (так как М5Ф05 5.0 оставляет больше 
памяти для работы 005-программ). Теперь также есть 
возможность запускать в окне ЭОЗ-программу, рабо- 
тающую в графическом режиме ѴСА. Версия содер 
жит больше описаний РІР для существующих про- 
грамм. Наконец, страничная подкачка (сйзк-ра^іп^) 
позволит пользователю запускать больше 005-про- 
грамм, чем под >УіпсІо>ѵ5 3.0. 

Расширение системы 

для новых компьютерных платформ 

>Ѵіпс1о\ѵ5 3.1 будет иметь специализированные рас- 
ширения для работы на новых компьютерных плат- 
формах. 
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1. \Ѵіп(к)\ѵ$ для Реп-компьютеров (Реп-Ьазесі Сот- 
ри Іегз). 

Графический пользовательский интерфейс, хоро- 
ший распознаватель символов и перо служат основой 
высокоинтуитивного и действительно “персонального" 
пользовательского интерфейса. Для использования по- 
тенциала Реп-компьютеров фирма МісгозоН разрабо- 
тала серию расширений для среды >Ѵіпекпѵз: 

- возможность ввода информации с помощью пера; 

- интерпретатор сообщений от пера, позволяющий су- 
ществующим программам для ЛѴіпбо^ и 005 
использовать перо; 

- модуль, открывающий доступ к технологии распо- 
знавания символов. 

2. МиШтесііа. 

Расширения среды ^іпс!о\ѵз 3.1 для тиііітесііа по- 
зволят пользователю включать в существующие про- 
граммы новые объекты — звук (аисііо), мультиплика- 
цию (апітаііоп), видео Циіі-тоііоп ѵісіео). Эти свойст- 
ва открывают целый класс таких тиііітесііа-докумен- 
тов, как энциклопедии, дополненные видео- и аудио- 
клипами, или каталоги, которые показывают движу- 
щиеся иллюстрации. Расширяемая архитектура \Ѵіп- 
сіоѵѵз дает возможность компьютерам тиііітесііа созда- 
вать дешевые системы для образования и для дома. 


3. Поддержка Ьаріор. 

Пользователи Ьаріор в версии 3.1 получат новое 
свойство, называемое “тоизе Ыиг“, которое позволит 
легко находить курсор на дисплее Ьаріор. Фирма Мі- 
сгозоН будет продавать лицензии фирмам-изготовите- 
лям на версии ^іпсклѵз в ПЗУ (РОМ). Это откроет 
путь к использованию новых типов компьютеров. 

Штрихи к портрету 

В версии \Ѵіпсіо>ѵ5 3.1 появилась возможность при- 
менения системного подхода к написанию общеупо- 
требительных диалогов типа: “Ореп...“ и “Заѵе аз...“. 
Эта возможность реализована через стандартную биб- 
лиотеку СОММОЬС.ОШ Это позволит вам иметь 
стандартный механизм выбора файлов, директорий, 
дисков и описаний масок файлов при работе ваших 
программ. В библиотеку также включена возможность 
использовать шаблон для диалога “АЬоиІ ...“. Фирма 
предлагает включать в него имя и организацию лица, 
зарегистрировавшего пакет, количество свободной па- 
мяти, памяти, доступной среде, и режим работы ^іп- 
сіоѵѵз. 

В настройке фонтов появилась возможность исполь- 
зовать псевдонимы. Так как многие существующие 
программы используют фонты Неіѵеііса и 
Тітез Ктп, а в версии 3.1 их больше нет, 
то с помощью псевдонимов вы можете 
определить любой из имеющихся у вас 
фонтов как Неіѵеііса или Тітез Ктп. По 
умолчанию они заменяются М8 Запз Зегіі 
и М3 Зегіі соответственно. 

В середине сентября 1991 года фирма 
МісгозоН выпустила вторую бета-версию 
продукта, а окончательный вариант по- 
явится к марту 1992 года. По инфор- 
мации, полученной в московском отделе- 
нии фирмы, Интернациональная версия 
\Ѵіпскпѵз 3.1 будет включать в себя встро- 
енные средства поддержки кириллицы, 
украинского и белорусского языка. Эта 
версия появится через два-три месяца по- 
сле выхода основного варианта продукта. 

Было сообщено также, что между фир- 
мами — производителями фонтов и ру- 
сификаторов для среды \Ѵіпс1о\ѵ5 достиг- 
нуто соглашение на стандарт располо- 
жения кириллицы в таблице А5СІІ: со 
1 92-“А“ по 255-“я“ символ. 

А.Зеленков 

По материалам: 

ЦЗЕИЕТ педѵз Ггот Сеог^е МООК.Е 
(МісгозоН Согр.) апсі Тот Наарапеп 
Шпіѵегзііу оі М^аіегіоо). 

РС ^еек. 

Іпіо \Ѵог1с1. 


ОИісеЬАМ! 


В Вашем офисе нужна именно она! 



ЗАБУДЬТЕ ПРО БЕГОТНЮ С БУМАГАМИ! 
ОНісеЬАЫ решает Ваши проблемы. 

ОДНОГО ПРИНТЕРА ХВАТИТ! 

(ЖісеЬАЫ сделает его доступным для всей команды. 

ЭКОНОМЬТЕ ВРЕМЯ НА ПОЛУЧЕНИИ ИНФОРМАЦИИ! 
ОНісеЬАЫ позволяет строить распределенные 
информационные системы. 

ВНУТРЕННИЙ ТЕЛЕФОН НЕ НУЖЕН! 

ОГОсеЦШ дает возможность общаться между собой. 

РАСШИРЯЙТЕ ВАШ ГМоѵеІІ Ыеі^аге! 

ОНісеЬАМ может и это! 

Дешевизна и простота установки делают 
ОШсеІ-АЫ доступной всем! 


Готова новая версия | 

I Обращайтесь /Ѵ\ I 


Лучшая среди равных! 


ОНісеЬАЫ! 

Равноправная сеть на последовательном интерфейсе 


Звоните сейчас! Приезжайте сегодня! 
Москва: (095) 341-01-13, 297-71-46. 
Санкт-Петербург: (812) 246-70-73. 
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В предыдущем номере мы рассказали о компьютерах- 
блокнотах. Они делают работу очень динамичной, не 
сковывая ваших перемещений. Но часто приходится 
результаты этой работы представлять на бумаге. 
Здесь вам поможет 


Сііігеп РШ8 — 
принтер для компьютера-блокнота 


Осенью 1991 года фирма СШхеп выпустила в 
продажу новый принтер РЖ8 МоІеЪоок Ргіпіег. 
Впервые показанный в конце мая на выставке 
СОМЭЕХ, проходившей в Калифорнии, он озна- 
меновал новый этап в развитии технологии пор- 
тативных устройств печати. Это первый порта- 
тивный принтер, обладающий качеством печати, 
которому может позавидовать огромный настоль- 
ный лазерный принтер. Раньше приходилось ми- 
риться с не слишком высоким качеством прин- 
тера, который можно было носить с собой. 

СШгеп РЖ8 — это машина, весящая всего 
лишь 900 г (1170 г с аккумуляторами) и печа- 
тающая 80 символов в секунду с разрешающей 
способностью 360 точек на дюйм. Размеры прин- 
тера также очень малы: высота 5 см, площадь 
основания 9x29 см. Теперь бизнесмен может 
иметь офис в портфеле с еще меньшими пробле- 
мами — габариты и вес делают РМ-48 отличным 
дополнением к компьютеру-блокноту. 

Принтер позволяет печатать на самых разных 
типах бумаги, в том числе на конвертах, этикет- 
ках и бланках. Кроме того, возможен вывод на 
пленку для проекции с помощью эпидиаскопа. 
Обычное деловое письмо печатается менее чем 
за минуту. 

В ЫР-48 использована технология термопере- 
носа — специальная лента при нагревании 
оставляет краситель на прижатой к ней бумаге. 
(Та же технология используется во всех совре- 
менных цветных принтерах, дающих качество, 
сравнимое разве что с качеством превосходной 
цветной фотографии.) Возможны два режима пе- 
чати: в первом из них, предназначенном для по- 
лучения высокого качества печати, каждый уча- 
сток ленты используется единожды. Второй ре- 


жим — для печати черновиков. В нем каждый 
участок используется неоднократно, что повы- 
шает ресурс красящей ленты в пять раз. Одной 
кассеты в нормальном режиме хватает на вывод 
35,000 символов, упаковка из шести кассет стоит 
15 долларов. В итоге стоимость печати получа- 
ется не слишком высокой, хотя страница обхо- 
дится дороже, чем при использовании лазерного 
принтера, но вы же не собираетесь держать этот 
принтер в качестве основного. Да и за портатив- 
ность, конечно, приходится платить. 

В принтере есть встроенный шрифт Соигіег, 
расширенный дополнительными эффектами 
вроде теней, обводного шрифта и так далее. 
Разумеется, принтер оснащен автозагрузкой 
бумаги. 

Принтер питается от встроенных никель-кад- 
миевых аккумуляторов, весящих всего 200 г. За- 
ряда батарей хватает примерно на четверть 
сотни страниц, что вполне достаточно для распе- 
чатки контракта нормального размера. Цена 
принтера — 549 долларов, но уже в ноябре в 
Штатах его можно было купить за 370. 

К принтеру, кроме всего прочего, прилагается 
руководство, выполненное в виде гипертекстовой 
системы на одной 3.5-дюймовой дискете. 

Принтер совместим с большим количеством 
популярных пакетов, а при работе с ^іпсіоѵѵз по- 
зволяет использовать все его возможности по ра- 
боте со шрифтами. 

И.Вязаничев 

Использованы материалы: 

Ке>ѵзЬу1е8 Ке1\ѵогк, Мау 20, 1991. 

РиЫізЬ, ЗерІетЬег 1991. 
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Агентство “КомпьютерПресс 44 
ЗАКАЗ НА ФЛОППИ-ЖУРНАЛ 


Ежемесячные обзоры материалов компьютерных журналов Америки , Европы и Японии по 
актуальным проблемам применения современной вычислительной техники и программного обеспечения , 
публикуемые на страницах компьютерного сборника "КомпьютерПресс”, пользуются большой 
популярностью среди отечественных пользователей ПЭВМ . Однако объем сборника не позволяет в 
полной мере удовлетворить интерес специалистов к некоторым достаточно узким , но актуальным 
проблемам компьютеризации. Поэтому редакция сборника, рассчитанного на широкую аудиторию 
пользователей ПК с самыми разнообразными запросами , считает необходимым приступить к изданию 
ряда специализированных приложений. Первое из них: 

ФЛОППИ-ЖУРНАЛ “БАЗЫ ДАННЫХ И ЭКСПЕРТНЫЕ СИСТЕМЫ 44 
В нем Вы можете найти: 

- аналитические обзоры материалов ведущих компьютерных журналов Америки, Японии и 
Европы, а также авторские статьи по проблемам разработки перспективных и применения 
уже существующих систем управления базами данных (СУБД) и экспертных систем (ЭС) ; 

- анализ состояния и тенденции национальных и международного рынка программной 
продукции; 

- практические рекомендации пользователям по работе с конкретными системами; 

- информацию о зарубежных и отечественных фирмах и разработчиках СУБД и ЭС; 

- календарь национальных и международных выставок, конференций и семинаров; 

- экспресс-новости и рекламу. 

Кроме того, в журнале будут публиковаться аннотации статей ведущих отечественных 
компьютерных журналов. 

И, наконец, под эгидой журнала будут проводиться ежегодные некоммерческие 
конференции по проблемам систем управления базами данных и экспертных систем (участие 
докладчиков оплачивается журналом). 

Журнал будет выходить на дискетах (по одной дискете 5.25“х360 Кбайт в каждом 
выпуске) шесть раз в год и распространяться только по подписке. Стоимость подписки на год 
(6 выпусков) — 450 руб., на полгода (3 выпуска) — 225 руб. 

Для того, чтобы подписаться на флоппи-журнал “Базы данных и экспертные системы 44 , 
достаточно перечислить соответствующую сумму (450 или 225 руб.) на расчетный счет 
ІЧо. 1467846 в Коопбанке Центросоюза СССР, корреспондентский счет N 0 . 161406 в ЦОУ 
Госбанка СССР МФО 299112, заполнить прилагаемый бланк заказа и отправить его вместе с 
копией платежного документа по адресу: 123459 Москва а/я 20. 

Контактный телефон в г. Москва — (095) 496-0578. 

ПЕРВЫЙ ВЫПУСК ФЛОППИ-ЖУРНАЛА “БАЗЫ ДАННЫХ И ЭКСПЕРТНЫЕ 
СИСТЕМЫ - В МАРТЕ 1992 г. 

ПРИГЛАШАЕМ ВАС К СОТРУДНИЧЕСТВУ С ЖУРНАЛОМ 
НА ВЗАИМОВЫГОДНОЙ ОСНОВЕ 


ПОДПИСАТЬСЯ НА НАШ ЖУРНАЛ НИКОГДА НЕ ПОЗДНО 



РАБОТАЕМ ГРАМОТНО 
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Корректор 

•) 


В этой статье читатель найдет 
полезные сведения об одной из 
разновидностей коммерческого 
программного обеспечения — программ 
проверки текстов на соответствие 
правилам русской орфографии, довольно 
быстро завоевавшей популярность 
у пользователей. Авторы статьи уже 
несколько лет работают над одной 
из популярнейших систем этого 
класса — программой ОРФО. 


Как выбрать программу 
проверки орфографии 


На отечественном рынке первые программы про- 
верки правописания появились немногим более полу- 
тора лет тому назад. К этому времени вкусы потенци- 
альных покупателей были уже сформированы отчасти 
рекламой, отчасти привычкой работать с аналогич- 
ными системами для английских текстов. 

В представлении покупателя, такая программа дол- 
жна уметь достаточно быстро проверять текст, исправ- 
лять ошибки, предлагать варианты правильного напи- 
сания слов, в которых были допущены ошибки, обла- 
дать возможностью пополнения словаря. 

Однако пользователь должен знать, что программа 
проверки русской орфографии, может содержать и не- 
заметные при покупке недостатки, которые в даль- 
нейшем сделают ее использование неудобным и невы- 
годным. Здесь мы расскажем, опираясь на свой опыт и 
отзывы покупателей, какие детали требуют от покупа- 
теля особенно пристального внимания. 

Несколько слов о программе ОРФО. Это резидент- 
ная программа, позволяющая использовать для про- 
верки и правки текста текстовый режим любого тек- 
стового процессора. Программа проверяет текст, види- 
мый в окне текстового процессора, и подсвечивает 
орфографические ошибки в словах, ошибки в согласо- 


вании прилагательных с существительными по роду, 
числу и падежу, ошибочно набитые вместо русских 
букв латинские, а также правильность расстановки 
знаков препинания и употребления прописных и 
строчных букв. 

Практика показывает, что наиболее требователь- 
ными пользователями программы проверки орфогра- 
фии являются редакторы издательств, имеющие дело с 
большими объемами текстов. Другие придирчивые 
пользователи — иностранцы, пишущие на русском, 
особенно преподаватели русского языка за рубежом. 
Здесь мы обсудим замечания именно этих категорий 
покупателей. 

Итак, что же должна уметь программа проверки 
правописания: 

1. Проверка текста 

По мнению большинства пользователей, проверка 
орфографии должна производиться во всем текстовом 
файле. При этом программа должна давать возмож- 
ность вернуться к ранее найденным ошибкам, а также 
изменить текст вокруг ошибки (контекст), а затем 
продолжить проверку. Большинство известных нам 
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КАК ВЫБРАТЬ ПРОГРАММУ ПРОВЕРКИ ОРФОГРАФИИ 


программ проверки русской орфографии не предостав- 
ляют пользователю такой свободы при проверке и 
правке текста, заставляя его проверять файл только 
сверху вниз, и позволяя править только само ошибоч- 
ное слово (как, впрочем, и большинство программ 
проверки английской орфографии). 

Учитывая пожелания пользователей ОРФО, в 
ОРФО 2.0 была включена функция проверки всего 
текстового файла, довольно неожиданная для рези- 
дентной программы. Автоматически пролистывая файл 
на экране и проверяя его до первой ошибки, ОРФО 
подсвечивает сразу все ошибки, попавшие на экран, и 
позволяет править любую из них или с помощью 
средств ОРФО, или средствами используемого тексто- 
вого процессора, либо сразу же перейти к проверке 
следующей страницы. 

Во вторую версию ОРФО, также с учетом предло- 
жений пользователей, добавлен режим автоматической 
проверки, благодаря которому при вводе текста с 
ошибкой сразу раздается звуковой сигнал. 

2. Программа должна быть 
совместимой с рабочей средой 

При покупке нужно обязательно удостовериться, 
что программа работает на вашем типе компьютера, с 
вашим типом монитора, и с кириллицей в использу- 
емой вами кодировке. 

Владельцы монохромных мониторов и нестандарт- 
ных кодировок кириллицы знают, сколь многие про- 
граммы оказываются для них неудобны или беспо- 
лезны. 

Сходную проблему представляет собой обработка 
различных текстовых форматов, т.е. возможность про- 
верять тексты, созданные с помощью популярных тек- 
стовых процессоров, например, МісгозоН \Ѵогб и 
ХѴогбреНесІ. 

Именно желанием разработчиков раз и навсегда 
обеспечить такую совместимость и объясняется, что 
ОРФО — резидентная программа, работающая с лю- 
бым текстовым процессором. Для проверки и коррек- 
ции текста с помощью пролистывания его в окне тек- 
стового процессора неважно, какой формат имел этот 
текстовый файл до его вызова на экран, это касается 
только самого текстового процессора. 

Конечно, такой прием позволяет обрабатывать 
только тексты, созданные в текстовом режиме, и 
исключает работу с текстовыми процессорами и изда- 
тельскими системами, использующими только графи- 
ческий режим экрана (подобными СНілѵгііег, Ѵепіига 
РиЫізНег и всем текстовым процессорам под 
АѴіпскпѵз). 

По сведениям авторов, файлы этих форматов до сих 
пор не обрабатывает вообще ни одна известная про- 
грамма контроля русской орфографии. 

Иногда за техническими и системными чертами 
программы бывает непросто увидеть и оценить ее ин- 
теллектуальное наполнение. 


3. Лингвистический интеллект 
программы — как его увидеть? 

Разработчики программ контроля правописания лю- 
бят поражать воображение покупателей тем, сколько 
тысяч слов в словаре их программы. Однако на самом 
деле эти цифры почти ничего не означают. Действи- 
тельно, что вам скажет тот факт, что словарь 
ОРФО 2.0 содержит более 200,000 основ? Ведь в сло- 
варе находятся основы слов, к которым при анализе 
текста программа приписывает окончания и фраг- 
менты чередования, а сколько слов программа может 
таким образом узнать и проверить в реальном тексте, 
понять очень трудно. Это зависит от количества и ка- 
чества правил образования слов из основ в данной 
лингвистической модели. 

Например, для основы глагола “делать 44 одна про- 
грамма может узнавать и проверять в тексте все его 
глагольные формы — “делаю 44 , “делаешь 44 , “делаете 44 
и так далее — всего около двадцати, а другая 
программа может еще узнавать и все формы его 
четырех причастий — “делающий 44 , “делаемый 44 , 
“делавший 44 , “деланный 44 во всех их падежах, родах и 
числах, — еще около восьмидесяти однокоренных 
слов, узнаваемых в тексте. Ясно, что словари этих 
программ могут содержать одинаковое количество 
основ, но при этом, вторая программа будет проверять 
текст точнее. 

Применение правил образования слов с дефисом и 
приставками также может сильно увеличивать количе- 
ство слов, узнаваемых программой в тексте. Напри- 
мер, если в словаре системы есть слова вроде “вызвал 
умную программу 44 , полезно выяснить, узнает ли про- 
грамма контроля орфографии слова “вызванная-таки, 
вызывал-вызывал, умный-умный, умную-преумную, 
поумнее, полпрограммы, программу-то, программе- 
корректору 44 и так далее. 

Покупателю кажется естественным определить ка- 
чество словаря программы именно по этому крите- 
рию — количеству не узнанных ею правильных слов в 
обычном тексте. Для этого обычно покупатели исполь- 
зуют свои собственные проверочные тексты. При про- 
верке такого текста правильно написанные, но не 
известные программе слова сразу бросаются в глаза. 

Пропущенные же ошибки невидимы и учету подда- 
ются плохо. Однако количество пропускаемых оши- 
бок — еще один очень важный критерий интеллекта 
программы. 

Если разработчики программы не утруждали себя 
точным описанием индивидуального способа измене- 
ния каждого слова и заложили в нее слишком простые 
и вольные правила словообразования причастий, мно- 
жественного числа существительных, кратких форм 
прилагательных, слов с дефисом и приставками, то 
может случиться, что программа разрешит писать 
“прыгаемый 44 , “мужественностями 44 , “дворцовы 44 , 
“смазочна 44 , “стол-таки 44 , “пользователя-новичку 44 , 
“преумный 44 и тому подобное, пропуская настоящие 
ошибки в тексте (особенно недописанные или неис- 
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правленные окончания слов). Для изучающего русский 
язык такой покладистый корректор окажется вообще 
бесполезным, так как он пропустит именно характер- 
ные ошибки. 

Увидеть, насколько строго программа проверяет 
правила образования слов (т.е. оценить ее норматив- 
ную функцию) можно с помощью текста из “плохих** 
слов и характерных ошибок, однако пользователю та- 
кой тест довольно трудно составить самому. 

Гораздо проще увидеть недочеты нормативной фун- 
кции исследуемой программы с помощью наблюдения 
за поиском замены к ошибочному слову. Попросите 
программу найти замену какому-нибудь короткому 
слову и оцените количество бессмысленных и некор- 
ректных вариантов, выдаваемых программой в каче- 
стве возможной замены. При проверке текста все эти 
ошибочные слова будут пропущены программой как 
правильные. 

Совершенствование нормативной функции про- 
граммы — трудный путь, он требует многих человеко- 
лет работы (например, на морфологическую модель и 
словарь ОРФО 2.0 затрачено более 10 высококвали- 
фицированных человеко-лет). 

4. Набор полезных умений и функций 

При оценке лингвистического интеллекта про- 
граммы следует также обратить внимание на то, умеет 
ли исследуемая программа выполнять следующие фун- 
кции: 

Проверка правописания слов, 
содержащих большие буквы 

Знает ли тестируемая программа, что слова 
“Москва**, “Иван** пишутся только с большой буквы, 
или она разрешит написать их и с маленькой 
(конечно, для этого требуется, как минимум, наличие 
в словаре программы собственных имен и названий). 

Например, программа ОРФО обнаружит в тексте 
неверно написанные слова “Санкт-петербург** и “Рио- 
Де-Жанейро“ и предложит правильные варианты 
(“Санкт-Петербург**, “Рио-де-Жанейро“) на замену. 
Это свойство программы проверки правописания осо- 
бенно полезно при проверке текстов, содержащих 
много фамилий и имен. 

Проверка правописания 
сложных слов с дефисом 

Слова с дефисом — камень преткновения для мно- 
гих иностранцев и русских. Как нужно правильно пи- 
сать — “естественно-научный** или “естествен нонауч- 
ный“, “полуживой** или “полу-живой“, “западно-си- 
бирский** или “западносибирский**? 

Очевидно, если программа такова, что разрешает 
написать через дефис любые два правильных слова, то 
слово “естественно-научный** будет считаться напи- 
санным правильно (а оно неправильное). 

ОРФО 2.0 в этом случае обязательно найдет 
ошибку и поставит соответствующий диагноз. Пользо- 


ватель увидит на экране сообщение “это слово обычно 
пишется слитно**. 

Проверка сокращений 
на наличие точки за ними 

Эта возможность обязательно нужна для проверки 
отчетов, форм, анкет, содержащих много принятых в 
них сокращений: “преп., ст., корп., акад., ред., ген., 
корр.“ и так далее. 

Обнаружение малой буквы 
в начале предложения 

Такая ошибка — случайная маленькая буква после 
точки — встречается довольно часто. 

ОРФО 2.0 разбирает каждую точку в тексте и кон- 
текст вокруг нее на соответствие одной из нескольких 
десятков схем (точка после сокращения, отточие, 
точка до кавычки и после, точка после инициалов и 
так далее), и решает в каждом случае, допустима ли 
здесь малая буква в следующем слове. 

Проверка знаков препинания 
на соответствие корректорским требованиям 

Кроме случайной малой буквы после точки суще- 
ствует большое количество довольно частых ошибок в 
знаках препинания. Сюда относятся и просто напеча- 
танные дважды запятые и точки, и другие знаки пре- 
пинания, и отсутствие пробела между запятой и сле- 
дующим словом, и неправильно перенесенные про- 
граммой форматирования на другую строчку 
(например, оторвавшийся от предложения вопроси- 
тельный или восклицательный знак) и многие другие 
ошибки. ОРФО 2.0 проверяет сочетания знаков пре- 
пинания на соответствие более чем ста правилам со- 
четаемости и расположения в тексте. 

Обнаружение и исправление вкравшихся в слово 
латинских букв или цифр. Каждое русское слово с не- 
чаянно набитой латинской буквой программа должна 
давать возможность автоматически исправить, так как 
часто латинская буква на глаз не отличается от рус- 
ской, а на печати может иметь небольшие отличия. 

Проверка слов с приклеившимися к ним циф- 
рами — дело не простое, так как программа не дол- 
жна бы подсвечивать в технических текстах названия 
микросхем, транзисторов и так далее. 

К сказанному добавим, что все без исключения ино- 
странцы, пишущие на таком трудном русском языке, 
высоко оценивают возможность ОРФО посмотреть на 
экране все формы любого правильного слова, хотя эта 
функция и не служит непосредственно проверке тек- 
ста. 

Пользователь программы проверки орфографии 
должен также иметь возможность посмотреть подроб- 
ные пояснения по каждому трудному случаю правопи- 
сания. 

Многие редакторы издательств отмечают также, что 
хотя бы простая проверка согласования слов и синтак- 
сиса в предложении жизненно важна для них. Они го- 
товы мириться с подсветкой мнимых ошибок 
(неполных предложений, разговорной речи и т.п.) 
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ради обнаружения как можно большего числа насто- 
ящих ошибок. 

И действительно, функция проверки согласованно- 
сти слов в предложении дает возможность находить 
даже ошибки в правописании слов, которые не удается 
найти, проверяя просто отдельные слова. Например, 
ни одна программа, проверяющая только правописа- 
ние слов, не найдет ошибку в предложении “Длинна 
моста сто метров 44 , ибо слово “длинна 44 правильное — 
оно есть в словаре как краткое прилагательное. 
Однако проверка согласованности слов сразу обнару- 
жит, что краткая форма прилагательного “длинный 44 
здесь неуместна, так как не имеет соответствующего 
согласованного существительного. 

Ошибки всех перечисленных типов программа дол- 
жна обнаруживать также и в новых словах, введенных 
пользователем. 

Для исправления ошибки любого типа очень по- 
лезно видеть на экране соответствующий диагноз про- 
граммы. 

Удобной чертой ОРФО 2.0 является именно такая 
способность давать развернутые пояснения к подсве- 
ченным ошибкам. Для каждой из них пользователь 
может посмотреть краткий диагноз, а также подробное 
объяснение причин, почему данная ошибка подсве- 
чена. 

При выборе программы контроля правописания 
нужно внимательно изучить средства пополнения сло- 
варя: очень важно, как вводятся в словарь новые 
слова — только в том виде, что в тексте (графически) 
или сразу во всех формах, с возможно более полной 
информацией. Придется ли вам последовательно вво- 
дить все формы вашей фамилии и затем обнаружить, 
что ту же фамилию, но в женском роде (фамилию 
вашей жены) программа все равно не узнает? 

Что касается ОРФО, то ее лингвистические знания 
позволяют определить правописание всех форм слова 
(которых бывает до 20) после трех-четырех вопросов к 
пользователю. Идеальная программа, по нашему мне- 
нию, должна определять все формы нового слова, за- 
давая один-два вопроса, а для некоторых слов — ни 
одного. 

5. Дружелюбный интерфейс 

Привычка к нелицензионным (т.е. краденым) за- 
падным программам сделала свое дело образования 
массы пользователей. Многие из них уже понимают, 
что программа должна быть: 

а) . Красивой. Это ясно всем, кроме многих 
советских программистов, до сих пор создающих меню 
с красными буквами на коричневом фоне, невидимые 
на дисплее с видеоадаптером типа ССА (не говоря уж 
о монохромном дисплее) или ядовитожелто-красные 
на синем, видимые даже из другой комнаты; 

б) . Удобной. Это означает, что в программе должны 
соблюдаться все сложившиеся стереотипы пользова- 
тельского интерфейса: наличие немногих легко запо- 
минаемых “быстрых клавиш 44 , стандартных назначе- 


ний основных клавиш (Е$с, Епіег, Ноте, Епб), 
использование для выбора меню, а не цифр — номе- 
ров позиций или ответов “Д/Н“ или “Ѵ/Ы“. Набор 
значащих клавиш программы не должен быть боль- 
шим и “плавающим 44 (скажем, выход из всех режимов 
должен происходить всегда при нажатии одной и той 
же клавиши). Весь диалог с системой в идеале должен 
состоять из немногих нажатий клавиш управления 
курсором и клавиш Епіег и Езс. 

Важность понимания этих элементарных принципов 
видна, например, из того, что даже многие западные 
программы, а также многие из современных программ 
проверки орфографии презирают удобство выбора 
файла из списка и предлагают раз за разом набирать 
имя файла вручную, всякий раз злорадно сообщая об 
ошибке (система >ѴѴ>ѴТЛѴС — >ѴНа1 Ѵои >Ѵап1, ТНаі 
Уои СеО. Об особой любви советских программистов к 
ответам “Д/Н“ при наличии у пользователей клави- 
атур разных стандартов нечего и говорить. 

Обязательно нужно, чтобы программа умела рабо- 
тать с манипулятором “мышь 44 ; 

в). Программа должна быть понятной. Это достига- 
ется благодаря развитой системе пояснений (оп-1іпе 
Неір) и подробной документации. 

В заключение можно добавить, что, по нашему 
мнению, наилучшая возможная система проверки тек- 
стов должна распространяться и на стиль (находить 
неправильные и тяжелые обороты — излишние место- 
имения “который 44 , например); проверять согласова- 
ние подлежащего и сказуемого и правильность управ- 
ления в предложении одних слов другими (находя 
ошибки типа “мыть руке 44 ); программа должна пред- 
лагать синонимы к любому слову и позволять встав- 
лять их в текст. Это дело будущего. 

А пока для выбора программы контроля правописа- 
ния покупателю нужно подготовить список своих тре- 
бований к качеству программы проверки текстов, со- 
ставить набор собственных тестов и заручиться сове- 
том профессионального программиста для уверенности 
в том, что купленная программа будет работать на 
нужном компьютере. Еще лучше для проверки совме- 
стимости программы взять у продавца демонстрацион- 
ную версию программы и на досуге “поиграть 44 с ней. 

И. Ашманов, Н.Руссова 


Адреса книжных магазинов — 
опорных пунктов агентства 
“КомпьютерПресс" по распространению 
журнала “КомпьютерПресс": 

1. 101000 Москва, Мясницкая, 6, “Книжный мир 44 

2. 630076 Новосибирск, Красный проспект, 60, 
“Техническая книга 44 , отдел “Книга почтой 44 . 

3. 191186 Санкт — Петербург, 

Невский проспект, 28, “Дом книги 44 . 

4. 310012 Харьков, ул. Свердлова, 17, 
“Техническая книга 44 , отдел “Книга почтой 44 . 
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аАНІОЫ — СУБД для профессионалов 


СУБД Сіагіоп (фирма Сіагіоп 5оН\ѵаге) предназна- 
чена для высококвалифицированных программистов, 
создающих сложные программные комплексы. Основ- 
ными составляющими этой СУБД являются язык про- 
граммирования для создания приложений и набор 
утилит для поддержки процесса программирования 
(основная из них — Оезі^пег). Сіагіоп первоначально 
создавался как средство проектирования интерфейсов. 
Однако разработка оказалась настолько удачной, что 
со временем превратилась в интегрированную систему 
для создания баз данных и средств работы с ними. 

По большому счету, Сіагіоп представляет собой 
язык программирования высокого уровня, предназна- 
ченный для создания управленческих, организацион- 
ных и экономических приложений (часто называемых 
деловыми). Язык имеет простой и ясный синтаксис. 
Поддержка экранных форм, отчетов, файлов, запросов 
к базе данных и т.п. осуществляется встроенными 
средствами языка, а не отдельными пакетами разра- 
ботчика, как, например, в сіВАБЕ. Сіагіоп является 
воплощением в современном виде концепции “для 
каждого класса задач свой язык программирования 44 , и 
с этой точки зрения его предшественником можно 
считать КОБОЛ. КОБОЛ, очень хорошо зарекомендо- 
вавший себя на больших ЭВМ, хотя и был перенесен 
на персональные компьютеры, не нашел на них ши- 
рокого распространения. И это вполне естественно, 
так как он учитывал специфику разработки не только 


круга деловых задач, но и техники. При переносе на 
ПК он был сильно изменен с целью удовлетворения 
возможностей работы с электронными формами, ба- 
зами данных, отчетами, сетями ЭВМ. Результатом 
явился сложный и запутанный синтаксис. За это 
время изменились также и характер деловых прило- 
жений, и требования к программному обеспечению 
(на главные роли вышли интерактивный режим, ак- 
тивная работа с экраном, широкие возможности гра- 
фической обработки данных). Кроме того, КОБОЛу, в 
котором отсутствует модульность, трудно конкуриро- 
вать с хорошо структурированными языками. Как ни 
странно, именно коммерциализация производства ПО 
для ПК послужила одной из причин появления Сіаг- 
іоп. На персональных компьютерах работает масса 
программ, предназначенных для области деловых при- 
ложений (электронные таблицы, текстовые процес- 
соры, СУБД, файловые системы, генераторы эксперт- 
ных систем и т.д.), но в этой сфере максимальный 
эффект дают программы, созданные по индивидуаль- 
ному заказу. А коммерческие системы (на создание 
которых тратятся огромные усилия), обладающие 
отличным качеством и предназначенные для широкого 
круга пользователей, не позволяют в каждом отдель- 
ном случае достичь максимума желаемого. Большим 
достоинством этих систем является простота использо- 
вания и разнообразие возможных приложений. С дру- 
гой стороны, простота языка неизбежно влечет за со- 
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бой ограниченность возможностей при попытке напи- 
сать достаточно сложную прикладную программу. 

Бесспорно, фактическим стандартом СУБД персо- 
нального компьютера остается 6ВА5Е. Основной со- 
ставляющей этой СУБД является язык управления БД. 
Этот класс языков появился одновременно с ПК. Ак- 
центируя внимание на работе с дисплеем и дисковой 
памятью, однозначно сопоставляя записи с экранными 
формами, эти языки при их применении очень сильно 
затрудняют разработку действительно сложных про- 
грамм. Центральную роль в таких СУБД играет Ад- 
министратор БД, который обычно в интерактивном 
режиме или с помощью меню выполняет процедурные 
операторы. Таким образом, работа с БД осуществля- 
ется без написания программы. Однако последова- 
тельность операторов, записанная в файл, уже стано- 
вится программой, а операторы Администратора БД 
становятся языком программирования (хотя сам Ад- 
министратор БД является интерпретатором). Сейчас 
(ІВАЗЕ-подобные СУБД вытесняются семейством 
Рагабох. По числу продаж Рагабох за первые шесть 
месяцев 1991 года прочно удерживал первое место. 
Однако несмотря на многие преимущества перед 
СІВА5Е, среди которых наиболее впечатляют средства 
работы с графикой, он остается представителем СУБД 
того же класса. 

Сіагіоп, в отличие от <1ВА5Е и Рагаёох, включает 
язык программирования в полном смысле этого слова, 
причем более высокого уровня, чем, скажем, Паскаль 
или Си. Правда, он ориентирован на определенный, 
хотя и крайне многочисленный класс задач. Как уже 
отмечалось, Сіагіоп состоит из собственно языковых 
средств и ряда утилит. Язык программирования Сіаг- 
іоп — это язык высокого уровня, подобный Паскалю, с 
некоторыми заимствованиями из РЬ/1, КОБОЛа, Бей- 
сика. В нем имеется набор средств для работы с дан- 
ными, файлами, управления экраном, построения 
отчетов. Широко представлены управляющие струк- 
туры. Синтаксис языка довольно прост. Написание 
символов не чувствительно к смене регистра. Первая 
позиция каждой строки зарезервирована под метку. 

Между разработчиками хорошо структурированных 
языков постоянно идет спор — что лучше, выделение 
знаками препинания окончания оператора (так сдела- 
но в СОВОЬ, АЭА, РЬ/1) или разделение операторов, 
как в языках Разсаі, Мо(1и1а-2, и какова при этом роль 
операторных скобок. В Сіагіоп принято очень интерес- 
ное решение — признаком окончания оператора мо- 
жет служить конец строки, начало комментария или 
точка с запятой. Оператор может быть перенесен на 
следующую строчку с помощью символа продолжения. 
В языке Сіагіоп для завершения группы операторов 
используется точка. Если группа операторов занимает 
много строк, она может быть завершена точкой, нахо- 
дящейся непосредственно под последним оператором. 
Операторы внутри группы должны иметь отступ. 

Типы данных представлены тремя видами целых 
чисел, упакованными вещественными числами пере- 
менной длины, вещественными числами с плавающей 


запятой двойной точности, строками с шаблонами, 
разнообразными формами представления дат. Все 
типы данных не нуждаются в специальном преобразо- 
вании при их совместном использовании. 

В Сіагіоп широко применяется выделение групп 
операторов, называемых структурами, для резервиро- 
вания специальных действий. Хотя это явно не огово- 
рено, в Сіагіоп имеются структуры с заранее обуслов- 
ленными именами, имеющие по умолчанию опреде- 
ленное функциональное назначение. Это, например, 
8СК.ЕЕЫ (работа с экраном), АЯЕА (описание овер- 
лейной области), МООІЛЕ (описание модулей-сочле- 
нов) и т.п. Структура КЕРОКТ предназначена для со- 
здания отчетов. Она описывает размер страницы, рас- 
положение заголовка, подножия страницы и тела 
отчета. При форматировании отчетов можно завести 
структуру отчета, изобразить его компоновку, внести с 
клавиатуры изменения и в итоге сгенерировать новую 
структуру отчета в разрабатываемой программе. 

Язык Сіагіоп очень компактен — в нем всего 25 за- 
резервированных слов, которые не могут быть мет- 
ками. Большинство ключевых слов не являются заре- 
зервированными и могут использоваться в качестве 
меток, что очень удобно. Так, например, структура 
описания экрана 5СКЕЕЫ может иметь и метку 
5СКЕЕЫ. Но программа РКОСКАМ не может иметь 
метку РКОС&АМ, так как это слово зарезервировано. 

Довольно тонким местом при составлении программ 
на разных языках высокого уровня является разбиение 
программ на модули. Это связано с необходимостью 
следить за корректным использованием локальных и 
глобальных ссылок, а также с организацией связи 
между модулями. В Сіагіоп программа состоит из 
основного модуля и модул ей-соч ленов. Глобальные 
данные описываются в основном модуле. При наличии 
в модуле-сочлене глобальных ссылок необходимо в нем 
указать основной модуль, в котором они были опи- 
саны, а не каждую глобальную переменную. Про- 
грамма, в которой находятся модули-сочлены или 
процедуры (функции), должна иметь структуру МАР, 
указывающую на них. 

Набор утилит Сіагіоп, входящих в состав СУБД, 
обеспечивает автоматизацию процесса проектирования 
и программирования базы данных. В него входят сле- 
дующие утилиты: 

Рііег — создание файлов Сіагіоп по тексту исходной 
программы; 

8оПег — управление файлами Сіагіоп; 

8саппег — отображение данных на экране в соответ- 
ствии со структурой БД; 

Сопѵепег — преобразование файлов из (в) формата 
Сіагіоп в (из) формат сІВАБЕ, ОІР, А5СІІ. 

Неірег — построение экранов помощи, связанных с 
полями, меню и другими экранами. 

ЕсІіІОГ — редактирование текстов программ Сіагіоп, 
имеются макросредства и обеспечивается прямой до- 
ступ к средствам форматирования экранов и отчетов. 
Ргосе$$ОГ — исполнение и отладка программ в ре- 
жиме интерпретации. Интерактивный отладчик 
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предоставляет полный набор стандартных возможно- 
стей, среди которых такие, как просмотр и изменение 
переменных, установка контрольных точек, трасси- 
ровка, повторное выполнение программы с произволь- 
ного. 

ТгапзІаІОГ — создание стандартных объектных моду- 
лей, соединение их с библиотечными модулями Сіаг- 
іоп и Си и создание в итоге ЕХЕ-файла. Обычно про- 
граммы, созданные этой утилитой, требуют меньше 
памяти и выполняются быстрее, чем созданные утили- 
той Ргосеззог. 

Оезі§пег — проектирование приложений. Ни одна 
СУБД не имеет такого мощного средства автоматиза- 
ции процесса проектирования приложений, как ути- 
лита Оезі^пег. Эта утилита используется с тремя це- 
лями — создание прототипа (макета) прикладной си- 
стемы, создание полностью готовых приложений и 
разработка каркаса (ядра) программы, который в 
дальнейшем будет дополнен более специфическими 
процедурами (при этом возможна и замена некоторых 
фрагментов кода, созданного Оезі^пег). Целый ряд 
возможностей (создание экранных форм, форматиро- 
вание отчетов, обработка файлов и т.п.) Оезі^пег и 
ЕсШог совпадает, но отличие заключается в том, что 
Цезі^пег при этом создает интерфейсное окружение и 
дает возможность получить полностью законченную 
программу без программирования. Эта утилита может 
быть вызвана либо из меню Сіагіоп, либо нажатием 
зарезервированных функциональных клавиш, либо не- 
посредственно из БОБ. Пожалуй, одним из самых 
больших недостатков Сіагіоп является то, что измене- 
ния, внесенные с помощью ЕсШог в текст, созданный 
посредством Оезі^пег, после возврата в Цезі^пег видны 
не будут. Более того, при проведении еще одного се- 
анса работы с Оезі^пег эти изменения полностью 
исчезнут. 

Для создания программы с помощью утилиты Ое- 
зі^пег необходимо, пользуясь подпунктами меню этой 
утилиты в интерактивном режиме, описать файлы, 
экранные формы, формы отчетов, экраны и режимы 
вывода помощи, а также меню приложения. После 
этого утилите задается режим создания исходного тек- 
ста программы на языке Сіагіоп для последующей 
обработки его компилятором. Откомпилированный 
текст программы может быть либо представлен в виде 
выполняемого файла, либо сразу же выполнен гип- 
1і те- процессором СКІІЫ. Утилита Оезі^пег дает эф- 
фективный исходный код на языке Сіагіоп. 

Необходимо подчеркнуть возможность создания 
приложений как для стандартной однопользователь- 
ской, так и для многопользовательской системы. В 
Сіагіоп имеются заготовки двух файлов-моделей для 
этих случаев ЗТАЫОАЯЭ.МОЬ и ЫЕТ\ѴОЕК.МОЬ со- 
ответственно. Эезі^пег на основе приведенных описа- 
ний объектов создает код, содержащий реализацию 
как объектов, так и логических связей между ними, и 
вставляет его в код генерируемой модели. 

Взаимодействие утилит Сіагіоп обеспечивает под- 
держку среды разработки, во многом аналогичную сре- 


дам общеизвестных языков на ПК. Так, находясь в 
ЕсШог, нажатием соответствующих клавиш можно 
обеспечить трансляцию и (или) выполнение редакти- 
руемой программы. При обнаружении ошибок тран- 
сляции они высвечиваются. Пользователь имеет воз- 
можность переходить от ошибки к ошибке и получать 
достаточно полные объяснения их причин. 

Управление экраном в Сіагіоп достаточно гибко. 
Компоновка экрана описывается структурой ЗСКЕЕЫ. 
В ней в виде строковых констант описаны графичес- 
кие символы и буквы, а в виде строк — экранные пе- 
ременные. Возможны создание меню, всплывающих 
окон и организация их взаимодействия с помощью 
специальных операторов. Большим достоинством явля- 
ется возможность форматирования экрана редактором 
Сіагіоп, который по заданной компоновке экрана со- 
здает экранную структуру, изображает компоновку эк- 
рана и, учитывая изменения, внесенные с клавиатуры, 
заменяет экранную структуру в проектируемой про- 
грамме. 

В Сіагіоп используется общепринятая для СУБД на 
ПК структура файлов, при которой в файле хранится 
заголовок, обеспечивающий компоновку файла и за- 
писи, а также сами записи. Ключи записей находятся 
в отдельном файле. Данные в файлах Сіагіоп хранятся 
с высокой надежностью, так как при отсутствии к 
нему запроса файл является логически закрытым. 
Кроме того, средства Сіагіоп дают возможность 
предусмотреть в программе автоматическое восстанов- 
ление файла при повторном выполнении программы, 
если ему предшествовал сбой в системе. Возможна 
защита обработки запросов. 

Последовательность обработки исходных файлов 
Сіагіоп (расширение СІА) следующая. Транслятор 
переводит исходный код в псевдокод, соответствующий 
командам виртуальной машины Сіагіоп. Файлы с 
псевдокодом имеют расширение РКО, указывающее, 
что они предназначены для обработки утилитой Рго- 
сеззог, которая сформирует обычный объектный файл 
с расширением ОВТ Одновременно создаются файл с 
адресами символов (тип 5ѴМ), с листингом трансля- 
ции (тип Ь$Т) и файл ошибок трансляции (тип ЕКЮ. 
Процесс трансляции всей программы организуется 
так, что при трансляции модуля-сочлена загружается 
файл символов и сразу транслируются адреса глобаль- 
ных данных. Это приводит к тому, что отпадает необ- 
ходимость в компоновке. Однако изменение глобаль- 
ных данных в программном модуле требует повторной 
трансляции всех используемых модул ей-соч ленов. 
Естественно, что программный модуль и модули-со- 
члены транслируются отдельно. Программный модуль 
начинается оператором РКОСКАМ и является голов- 
ным файлом, в котором находятся описания гло- 
бальных переменных, процедуры, функции, структура 
МАР и сам текст программы. 

Структура МАР обязательна, если в программном 
модуле есть процедуры, функции или модули-сочлены, 
так как она обеспечивает компоновку всей программы. 
В модулях-сочленах МАР присутствовать не может. 
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Структура МАР может состоять из операторов РРОС, 
РІІЫС, МООІЛ.Е, АКЕА и ОУЕКІАУ. Структура 
МООШЛі предназначается для объявления модулей- 
сочленов со всеми их внутренними процедурами и 
функциями. Эта структура обязательно должна быть 
внутренней по отношению к структуре МАР. Внутри 
программы, процедуры или функции оператор С(ЮЕ 
отделяет раздел данных, в котором содержатся опера- 
торы описания, от раздела исполняемых операторов. 
При организации взаимодействия процедур и функций 
локальные параметры передаются по значению, а 
внешние параметры — по адресу. Функции в Сіагіоп 
делятся на два типа: библиотечные функции, встроен- 
ные в язык Сіагіоп, и функции, написанные пользова- 
телем, которые должны быть указаны как параметр 
оператора РІЖС в структуре МАР. Аналогично проце- 
дуры должны быть указаны в качестве параметра опе- 
ратора РКОС в структуре МАР. Первым оператором 
программного модуля всегда служит оператор РРО- 
СКАМ. Модуль-сочлен является файлом с операто- 
рами, первый из которых — МЕМВЕК. Директивы 
транслятору могут находиться в произвольном месте 
программы. Операторы описания могут определять не 
только константы и переменные, но и файлы, отчеты, 
экраны, таблицы памяти. Локальные подпрограммы не 
содержат операторов описания, не имеют параметров, 
и обращение к ним возможно только из содержащей 
их программы, процедуры или функции. Язык содер- 
жит многочисленные функции для работы с клавиату- 
рой, дисплеем, файлами. Возможно расширение языка 
программами, написанными на других языках 'про- 
граммирования. 

Операторы обработки экранов взаимодействуют не- 
посредственно с видеопамятью ПК. Структура экрана 
в Сіагіоп определяется экранной формой, которая со- 
стоит из изображаемых символов, видеоатрибутов и 
полей ввода информации. Экранная форма описывает- 
ся структурой ЗСРЕЕЫ. Она начинается с одноимен- 
ного оператора. Эта структура активизируется опера- 
тором ОРЕЫ и завершается — СШ5Е. Концепция ра- 
боты с экраном в Сіагіоп сочетает удобство програм- 
мирования с эффективным использованием возмож- 
ностей монитора. Первое обеспечивается возможнос- 
тью создавать экранную форму в редакторе Сіагіоп. 
Предусмотрена возможность непосредственной органи- 
зации окон и меню. Для работы с отчетами в Сіагіоп 
служит структура КЕРСЖТ, которая содержит фор- 
маты и атрибуты, определяющие оформление страниц. 
Как и при работе с экраном, структура КЕРСЖТ мо- 
жет создаваться и форматироваться в редакторе. 

Хорошо известно, что далеко не каждая программа 
занимает всю память, отведенную под нее. В Сіагіоп 
есть средства для экономии такой избыточной памяти. 
В Сіагіоп имеются возможности доступа к файлам 
ООЗ. Некоторые команды Сіагіоп и 005 для работы с 
файлами совпадают. Для ряда команд 003 в Сіагіоп 
имеются аналоги. В Сіагіоп при организации работы с 
памятью предусмотрен такой необычный объект, как 


таблицы памяти. Они предназначены для хранения 
элементов, между которыми задан порядок следова- 
ния, в памяти, оставшейся свободной после загрузки 
программы. Элементы по отношению к таблицам па- 
мяти играют такую же роль, как записи по отноше- 
нию к файлу. С точки зрения структур данных таб- 
лицы памяти представляют двунаправленный список, 
т.е. список, в котором каждый элемент списка имеет 
ссылку на предыдущий и на последующий элементы. 
Элементы такого списка не обязательно должны рас- 
полагаться в памяти подряд, что предоставляет широ- 
кие возможности по работе с памятью. По существу, 
это концепция динамической памяти с возможностями 
получать память из “кучи“ и возвращать ее обратно. 
Таблица памяти может содержать до 65536 элементов 
длиной до 65520 байт каждый. Таблицы памяти опи- 
сываются структурой ТАВБЕ, а доступ к ним обеспе- 
чивается при помощи указателя элемента. 

В Сіагіоп имеется богатый набор математических 
функций с достаточно простым синтаксисом. 

В СУБД Сіагіоп допускается обработка транзакций 
в сети. Асинхронные взаимодействия, обработка фай- 
лов формата бВАЗЕ 111 обеспечиваются программой 
Ьап^иа^е Ехіепзіоп Мобиіез. 

Следуя Кернигану и Риччи, которые считают, что 
первой программой при встрече с любым новым язы- 
ком должна быть та, которая выдает на экран некото- 
рые слова типа “Неііо, \ѵогсІ“, приведем ее. 

ТІТІ_Е (’РІПЗТ РПООРАММ ' ) 

НЕ1_1_0 РРЮОРАМ 
І_АѴ01ІТ ЗСРЕЕМ 

РОѴу/ ( 15 , 40 )ЗТРІЫС( ’НеІ Іо, ’ ) 
Р0М(18.45)5ТРІМС( ’и/огсі! * ) 

ССЮЕ 

0РЕМ(1_АѴ01ІТ) 

РЕТІІРМ 

В этой программе первая строчка задает заголовок 
листинга трансляции, а вторая содержит метку (имя) 
программы и оператор начала программного модуля. 
Структура ЗСРЕЕЫ описывает экранную форму и 
имеет метку ІАУОІЛГ. Строка Неііо начинается на 
экране с сорокового столбца пятнадцатой строки, а 
строка >ѵогс1 — с 45 столбца восемнадцатой строки. На 
этом раздел описаний заканчивается. Раздел кодов со- 
стоит из операторов ОРЕЫ, который выводит создан- 
ную экранную форму на экран, и РЕТІЖЫ, который 
завершает выполнение программы. 

Приложения, созданные в Сіагіоп, имеют высокую 
эффективность и надежность. Сообщения об ошибках 
исчерпывающи и понятны, а встроенная консультаци- 
онная система обеспечивает достаточный уровень для 
сопровождения пользователя в процессе работы. 

к. ф-м. н. А.Смородинский 
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СІВА5Е IV для 


Серия статей предназначена в первую очередь для 
обучения пользователей работе с системой. Мы не бу- 
дем касаться вопросов написания программ, так как 
это дело профессионалов и лучше программиста про- 
грамму все равно не напишешь. Другой разговор, что 
при наличии ОВА5Е IV нам и ,не нужны 
программисты. Тем более, что прежде, чем написать 
даже небольшую программу, они будут долго ходить к 
вам и спрашивать как бы вы хотели, чтобы эта 
программа работала. Вы будете долго объяснять им, 
чего бы желали получить. В результате вы разойдетесь 
в полной уверенности, что все будет хорошо, но когда 
через несколько месяцев программисты придут и 
покажут, что же все-таки получилось, программа 
будет работать совсем не так, как вы себе это 
представляли. Вы будете недовольны, но вам докажут, 
что все сделанное полностью соответствует 
техническому заданию, которое вы подписали после 
обсуждения (а вы просто были очень заняты и некогда 
было вникать в смысл этой бумаги, тем более, что от 
обилия специальных терминов у вас закружилась 
голова). Вам скажут, что доработки потребуют 
времени и денег. И в конце концов вам придется 
работать с несимпатичным средством или же просто 
не пользоваться им. 

Сколько потрачено нервов и денег! Ну, деньги-то 
ладно, а нервные клетки не восстанавливаются. 

Конечно, если потребуется сложная программа, все 
равно придется обращаться к программистам. Но могу 


Н иногда не поздно начать с начала. И 
если вы только что купили 
персональный компьютер, а к нему 
хорошее программное обеспечение (у 
легальных поставщиков), то не плохо 
было бы начать обучение прямо сейчас. 
И поможет вам не кто иной, как 
КомпьютерПресс. С этого выпуска мы 
начинаем публикацию серии уроков по 
йВА5Е ГѴ для начинающих. Успехов вам! 


начинающих 


открыть маленький секрет: сложную программу хо- 
рошо написать могут только настоящие професси- 
оналы, а с ними и хлопот будет меньше — опыт у них 
большой. 

Но для достаточно простой системы (например, 
личная адресная книга, библиографический каталог 
или телефонный справочник) программа и не потре- 
буется. Изучив работу с системой ОВА8Е IV, вы все 
сможете сделать сами. Тем более, что для овладения 
основами работы с этим пакетом программ не потре- 
буется много времени. В большинстве глав 
разбирается один и тот же пример, поэтому по 
окончании обучения вы будете иметь на своем 
компьютере персональную справочную систему. 

Итак, если вы решились, вперед! 

Глава 1. Первоначальные сведения 
о базах данных 

1.1. Что такое база данных 
и система управления ею 

База данных — это особым образом организованная 
совокупность взаимосвязанных, хранящихся вместе 
данных. Примерами баз данных могут служить адрес- 
ная книга, картотека, поваренная книга, словарь и эн- 
циклопедия. 

Давайте поближе рассмотрим такую простейшую 
базу данных, как ваша телефонная записная книжка, 
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которой вы пользуетесь каждый день. В нее заносятся 
фамилии, номера телефонов и адреса абонентов, а 
также некоторые дополнительные сведения. 

Для этих данных в записной книжке отводится 
отдельная строка (см. рис. 1.1). Пользуясь терминоло- 
гией баз данных, каждая строка телефонной книжки, 
соответствующая информации об одном человеке, на- 
зывается записью. Каждая запись состоит из полей 
(фамилия, телефон и т. д.). Совокупность всех запи- 
сей составляет базу данных или файл базы данных (в 
дальнейшем файл). Список полей — это структура 
базы данных. 


Фамилия 

Адрес 

Телефон 

Кузнецов И . И . 

Кутузовский пр . , 

145-23-18 


д . 17 , кв . 6 


Лунин А.М. 

пр . Мира, д. 12, 

356-13-12 


кв . 23 



Рис. 1.1. База данных (телефонная книжка) 


Ваша телефонная книжка устроена определенным 
образом — она позволяет заносить сведения о ваших 
знакомых (на бумагу с помощью ручки), быстро отыс- 
кивать нужную вам фамилию с помощью алфавита. 
Можно сказать, что ручка и алфавит управляют вашей 
базой данных (телефонной книжкой). 

Таким образом, вы ежедневно много раз пользова- 
лись базами данных. Вы искали в них информацию, 
добавляли, изменяли или удаляли ее. Другими сло- 
вами, вы управляли этой информацией. И можно ска- 
зать, что вы опытный пользователь. 

Система управления базами данных (СУБД) — это 
средство управления данными: она обеспечивает воз- 
можность изменения и добавления данных и поиск 
конкретных элементов. ЭВА8Е IV — это система 
управления реляционной базой данных. Этот термин, 
“реляционная", требует пояснений. 


Дело в том, что база данных в сШАЗЕ рассматрива- 
ется как совокупность прямоугольных таблиц. Каждая 
строка такой таблицы — запись, а каждый столбец — 
поле (см. рис. 1.2.). 

1.2. Начнем, пожалуй! 

Говорят, что самый лучший способ научиться ка- 
кому-нибудь делу — это начать его делать. 

Будем считать, что вы знаете, как переходить из 
одной директории в другую в операционной системе 
МЗ-ЭОЗ. 

1. Наберите на клавиатуре команду запуска системы: 
ёЬазе и нажмите на клавишу Епіег. 

2. Если на экране появится Управляющий Центр 
(Сопігоі Сепіег) (см. рис. 1.З.), тогда перейдите к 
пункту 4. 

Саіаіод Тоо($ Ехіі 4:24:18 ря 

6ВАЗЕ IV С0МТР01. СЕМТЕН 
САТА106: С:\0ВА$Е\1ЖТ1ИЕ0.САТ 


Эаіа 

Оиегіез 

Рогшз 

ЯерогЧз 

1.аЬеі$ 

Арріісаііопз 

|сгеаіе| 

сгеаіе 

сгеаіе 

сгеаіе 

сгеаіе 

сгеаіе 








РПе: Ме* РПе 

Оезсгіриоп: Ргезз ЕИТЕЯ оп <сгеаіе> Іо сгеаіе а пе* Ше 

НеірРІ ІІве: 0аІа:Р2 Оезідл : 8М71-Р2 Оѵііск Нерог і 8ЫРГ-Р9 Мепив: РІО 

Рис. 1.3. Управляющий центр сІВАЗЕ 

3. Если ваша система установлена так, что при за- 
грузке выводится приглашение для набора команд 
(1ВА8Е (командная строка — точка над строкой со- 
стояния, см. рис. 1.4), то нужно набрать на клави- 
атуре команду аззізі и нажать клавишу Епіег. 


поле 1 поле 2 поле 3 

. . поле п 



запись 

1 


запись 

2 



запись 

т 


ОагаЬазе | С:\ОЬа$е\<МЕЫ> | РіеіО 1/1 | | 


Рис. 1.4. Командная строка (ША8Е 

4. Теперь рассмотрим, что из себя представляет 
управляющий центр. 

1.3. Приемы работы 
с управляющим центром 


Рис. 1.2. Таблица реляционной базы данных 
В терминах СУБД подобные таблицы называются 
отношениями (отношение — геіаііоп, англ.). Отсюда и 
название модели базы данных — реляционная. 


Перед вами на экране шесть панелей. В панелях 
содержатся списки файлов различных типов. Таких 
типов — шесть. Столько же, сколько и панелей: 

1) панель Ваіа — файлы базы данных (*.с!ЬО; 
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Іауоііі Огдапіге Аррепй Со То Ехі* 4:26:47 рт 

ВИе$ гетаіпіпд; 4000 


Мит 

Р і е 1 сі Мате 

Ріе 1 (1 Туре 

Ѵ/ісШі 

Ре с 

1 псіех 

1 

1 

СЬагасіег 



N 


ОаіаЬазе | С:УН>азе\<№И> |РіеІСІ 1/1 | | 

Етег іпе Ме1<1 пате. Іпзег*/0еіе*е Пеіб: СТйІ-И/Сиі/и 
Ріеій патез Ьедіп а іе«ег апо шау сопіаіп іеиегз. йідііз апй ипйегзсогез. 

Рис. 1.5. Экран проектирования баз данных 


2) панель (^иегіез — файлы запросов (расширение 
.цие). Содержат инструкции для манипулирования 
данными; 

3) панель Рогтз — файлы форм (расширение ігш). 
Используются для ввода, редактирования и про- 
смотра информации; 

4) панель Керогіз — файлы отчетов (.Іго). Эти файлы 
содержат отчеты по данным базы. Данные выводятся 
на экран или печатающее устройство в специальном 
формате; 

5) панель БаЬеіз — файлы этикеток (.1Ы). Файлы 
этого типа очень похожи на файлы предыдущей па- 
нели, за исключением того, что отчет выводится на 
печать в виде этикеток (карточек); 

6) панель Арріісаііоп — приложения. Эти файлы со- 
держат написанные программы, которые выполня- 
ются СУБД. 

Во всех панелях вы можете сделать два выбора: со- 
здать новый файл, выбрав «сгеаіе», или открыть уже 
созданный файл. 

Панель Оаіа (данные) является в данный момент 
активной, на маркере «сгеаіе» стоит курсор (курсор — 
подсвеченный прямоугольник). Для того чтобы пе- 
рейти в другую панель, вы можете нажать на клавишу 
«стрелка вправо», и курсор передвинется на панель 
запросов. Нажимая таким образом на эту клавишу не- 
сколько раз, мы можем пройти все панели управля- 


Ыит 

Р і е 1 сі Мате 

РіеМ Туре 

У і сіі И 

Оес 

1 пгіех 

1 

РАМ 

СЬаг ас іег 

20 


N 

2 

ІМІА 

О.агасіег 

12 


N 

3 

ОТСНЕЗТ 

СЬаг астег 

15 


N 

4 

А0РЕ5 

СЬагасіег 

50 


N 

5 

ТЕ1-ЕР0М 

СЬаг ас іег 

7 


N 

6 

РРІМ 

Мето 

І 

10 


N 


Рис. 1.6. Информация о полях базы данных 


ющего центра и вернуться обратно. Курсор факти- 
чески движется по кругу, его движение зациклено. 
Для того чтобы перейти, например, из панели Данных 
в панель Приложений, не обязательно пять раз нажи- 
мать клавишу «стрелка вправо», можно перейти в 
нужную панель, нажав только один раз клавишу 
«стрелка влево». 

Но вернемся к панели данных. Теперь мы попро- 
буем создать файл базы данных для нашей телефон- 
ной записной книжки. 

1.4. Создание файла 
базы данных 
телефонной книжки 

1. Установив курсор на маркер «сгеаіе» панели Оаіа, 
нажмите клавишу «Епіег». Перед вами появится эк- 
ран проектирования базы данных (рис. 1.5.) с курсо- 
ром в колонке Ріеід Ыаше (имя поля). 

2. Наберите на клавиатуре название первого поля на- 
шей телефонной книжки (латинскими буквами): 
РАМ (фамилия). 

3. Нажмите «Епіег» для перехода к следующей ко- 
лонке Ріеіб Туре (тип поля). 

В 6ВА5Е поля могут быть шести типов: 

- символьное (СНагасіег) — любые символы, величина 
поля — 274 символа. 

- числовое (ЫишЬег) — любые числа, величина поля 
до 20 знаков; 

- числовое поле с плавающей точкой (Ріоаі). Исполь- 
зуется в основном в научных приложениях; 

- логическое (Ьо^ісаі) — длина поля — 1 символ. Со- 
держит или знак Т (ігие — истина), или Р (Ызе- 
ложь); 

- поле даты (Эаіе) имеет длину 8 символов, содержит 
день, месяц и год, причем в специальном формате, 
например, 21 августа 1991 года будет представлено в 
(ІВА5Е как 21.08.91. Точки называются разделите- 
лями (в качестве разделителя можно использовать и 
знак в зависимости от того, как установлено в 
(1ВА5Е). 

- поле памяти (тето). Это текстовое поле может быть 
использовано для написания больших документов, 
ограниченных только размерами свободной памяти. 
Данные будут размещены в дополнительном файле с 
расширением ЬВТ. 

По умолчанию в сіВАЗЕ IV тип поля является сим- 
вольным (СНагасіег), поэтому это значение уже по- 
явилось в поле ввода. 

4. Нажмите клавишу «Епіег». Курсор перейдет в ко- 
лонку ЛѴісІіН (ширина поля). 

5. Наберите 20 и нажмите «Епіег». Курсор автома- 
тически перейдет в колонку Іпбех (об индексе попоз- 
же), перескочив через колонку Оес (десятичное), ко- 
торая заполняется только для числовых полей. 

6. Не беспокойтесь сейчас об индексе и нажмите 
«епіег». В колонке Ышп (номер) появляется число 2, 
и курсор передвинется на следующую линию. Вы 
можете вводить информацию о втором поле. 
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«1ВА5Е IV ДЛЯ НАЧИНАЮЩИХ 


іауоиі Огдапіге Аррепсі Со То Ехіі 4:26:47 рл 

Ві*е$ гелаіпіпд: 4000 


Миш 

Еіеісі Мате 

РіеІсі Туре 

Ѵ/ісііЬ 

Оес 

1 пгіех 


1 

2 

3 

4 

5 

6 
7 

РАМ 

ІМІ А 

0ТСНЕ5Т 

АЭРЕЗ 

ТЕІ_ЕРО\І 

РРІМ 

СЬагасіег 

Оіагастег 

20 


N 

1 Заѵе аз: ТЕІ.ЕР 



II 







Оаіабазе | С : \(1Ьа$е\<ИЕИ> | РіеісІ 1/1 | | 

2оол: Р9 Ассері: - СапсеІ : Е$с 

Ріеій палез Ьедіп а Іеиег апй лау сопіаіп іеиегз. <Лдіі$ апй ипбегзсогез. 

Рис. 1.7. Сохранение структуры файла .дЫ на диске 


7. Повторите шаги 1-6 для ввода информации о полях 
(см. рис. 1.6.). 

8. Нажмите клавишу «Епіег», когда курсор окажется в 
седьмом пустом поле. Перед вами возникнет при- 
глашение для ввода названия файла (8аѵе аз — Со- 
хранить как) (рис. 1.7.). Введите имя вашего 
файла — ТЕЬЕР и нажмите «Епіег». 

9. Внизу экрана появится вопрос (1ВА5Е к вам: 

Іприі сіаіа гесогсіз пош? (Ѵ/1Ч) 

Вводить данные сейчас? (Да/Нет) 

10. Нажмите У (Да). 

1.5. Ввод данных 

Перед нами экран (см. рис. 1.8.). Он называется 
экраном режима Редактирования (ЕсШ). 

Появится пустая запись с курсором в поле РАМ, го- 
товая для ввода информации. Введем первую запись 
(после ввода информации в каждое поле не забудьте 
нажимать Епіег): 


Ресогсіз Со То Ехіт 4:32:45 рт 



Рис. 1.8. Экран режима редактирования (1ВА5Е 


1 

РАМ 

Данилин 

2 

ІМІА 

Виктор 

3 

ОТСНЕ8Т 

Иванович 

4 

АйРЕ8 

ул. Маршала Захарова, д.12, кв. 89 

5 

6 

ТЕБЕРОЫ 

РРІМ 

393-40-04 


Последнее поле заполнять не надо. О работе с по- 
лями памяти поговорим попозже. 

Введем еще несколько записей: 


1 

РАМ 

Большакова 

2 

ІМІА 

Татьяна 

3 

0ТСНЕ8Т 

Александровна 

4 

> 

о 

33 

гп 

со 

ул. 13 Парковая, д.22, кв. 3 

5 

6 

ТЕІ_ЕР0Ы 

РРІМ 

464-35-43 


1 

РАМ 

Ушакова 


2 

ІМІА 

Елена 


3 

0ТСНЕ8Т 

Алексеевна 


4 

АОРЕ8 

Армянский пер . 

, д . 10 , кв . 3 

5 

ТЕБЕРОМ 

385-15-12 


6 

РРІМ 




Маленькое замечание, прежде чем вы будете вво- 
дить следующую запись. В ёВАЗЕ IV русские заглав- 
ные буквы “К“ и “Н“ не вводятся, вместо них надо 
использовать их латинские эквиваленты — “К“ и 
“Н“. Это маленькое неудобство, но с ним приходится 
мириться. 


1 

РАМ 

Кожухова 

2 

ІМІА 

Ольга 

3 

0ТСНЕ5Т 

Альбертовна 

4 

АЭРЕ5 

ул. Сталеваров, д.10, кв. 15 

5 

6 

ТЕ1_ЕР0Ы 

РРІМ 

404-35-04 


1 

РАМ 

Чесаков 

2 

ІМІА 

Давид 

3 

0ТСНЕ5Т 

Моисеевич 

4 

со 

ш 

ос 

о 

< 

ул. Тверская, д.10, кв. 50 

5 

6 

ТЕЬЕРОМ 

РРІМ 

285-56-82 


После того как вы ввели последнюю запись, на- 
жмите на комбинацию клавиш СігІ-ЕпсІ для сохране- 
ния информации в вашем файле данных. 

А. Иванов 

(продолжение следует) 
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КОНКУРС 

«ЛУЧШАЯ ПУБЛИКАЦИЯ 1992 ГОДА» 


Агентство «КомпьютерПресс» в 1992 году продолжает 
конкурс на лучшую публикацию, посвященную вопросам 
применения вычислительной техники в нашей стране 
и за рубежом. 

Победителей ждут премии: 

1 премия — 5000 рублей 

2 премия — 3000 рублей 

3 премия — 1000 рублей 

10 поощрительных премий — годовая подписка на журнал 
«КомпьютерПресс» . 

На конкурс принимаются статьи объемом до 2 авторских 
листов (80 Кбайт) в машинописном виде или на дискете 
в формате МісгозоЙ \Ѵогё или АЗ СИ. В конце статьи 
необходимо указать список использованных источников 
в виде: автор, название источников на языке оигинала, 
месяц и год издания. 

Лучшие работы будут опубликованы на страницах 
«КомпьютерПресс» . 

Работы присылать по адресу: 113093 Москва, а/я 37. 
Переводы на конкурс не принимаются. 

В конверт следует вложить лист с указанием фамилии 
и имени автора, обратного адреса, телефона, ученой 
степени, краткого описания (не более 100 символов) 
сферы научных и технических интересов. 

Желательно приложить копии использованных материалов. 



ВНИМАНИЮ ВЛАДЕЛЬЦЕВ ПЕРСОНАЛЬНЫХ КОМПЬЮТЕРОВ! 



В АШИ ИНТЕЛЛЕКТУАЛЬНЫЕ И КОММЕРЧЕСКИЕ 
ВОЗМОЖНОСТИ МНОГОКРАТНО ВОЗРАСТУТ, ЕСЛИ ВЫ 
ДОПОЛНИТЕ СВОИ АРМы МОДЕМОМ ИСМ-1200 


Асинхронный полудуплексный внешний модем 
ИСМ-1200 предназначен для передачи 
текстовой и графической информации между 
компьютерами, находящимися на любых 
расстояниях друг от друга по обычной 
телефонной сети (внутренней, городской, 
междугородной) . 


Достоинства: 

- соответствует международному стандарту Ѵ.23 
ССІТТ и требованиям общегосударственной 
телефонной связи 

- обладает преимуществом по сравнению с 
зарубежными Науез-совместимыми модемами 
стандартов Ѵ.22 и Ѵ.22Ъіз МЫР5 по надежности 
и устойчивости передачи данных при 
использовании на отечественных телефонных 
линиях 

- доступ к биржевой, банковской, коммерческой, 
справочной информации, в базы данных и 
получение других услуг через информационную 
систему “СИНТЕК“ 

- широкий спектр программного обеспечения 


Технические характеристики: 

- связь модема с компьютером через 
последовательный интерфейс К8-232С 

- использование с ІВМ РС ХТ/АТ, ЕС 1841-1845 
Искра 1030, Турбо 86М, Микро 86 и другими 

- стандарт Ѵ.23 ССІТТ 

- скорость передачи 300-1800 бит /с 

- габаритные размеры 252x175x66 мм 

- масса 1.8 кг 


МОДЕМ ИСМ-1200 — ЭТО 


ТОВАР ВЫСШЕГО 
КАЧЕСТВА 


ФИРМЕННЫМ 
СЕРВИС ДЛЯ 
ПОЛЬЗОВАТЕЛЯ 


ДОСТИЖЕНИЯ 
САМОЙ ПЕРЕДОВОЙ 
ТЕХНОЛОГИИ 


Гарантийное и послегарантийное обслуживание, обучение, 
консультации и поддержка тысяч пользователей модемов 
осуществляются нашими представительствами в 45 городах 
страны. 


Приглашаем партнеров для взаимовыгодного 
сотрудничества и открытия региональных 
представительств фирмы 

Розничная цена модема ИСМ-1200 — 3500 рублей (декабрь 1991) 
Оптовым покупателям предоставляется скидка 
Немедленная поставка без предоплаты 


НАУЧНО-ПРОИЗВОДСТВЕННАЯ ФИРМА “ МАСТАК ‘ 

107241 Москва, а/я 13. Факс: (095)360-78-74 
Фирменное обслуживание: Москва, у л. Знаменская, 8. 
Телефон: (095)168-20-21 
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Часто ли у вас бывают отпуска? Всего раз в год? Но 
зато сколько удовольствий и воспоминаний! 

Для 36-летнего председателя совета директоров Мі- 
сгозоН отпуск — всегда проблема. Когда-то он считал 
невозможной даже мысль об отдыхе, сейчас он, хоть и 
неохотно, порой отправляется в увеселительные по- 
ездки, но только предварительно определив их цель. 

“В одном из наших путешествий мы большую часть 
времени занимались физикой, — вспоминает в интер- 
вью журналу РІауЬоу бывшая подруга Гейтса Энн 
Уинблад > — Мы слушали кассеты с записями лекций 
Ричарда Фейнманна и читали всевозможные книги по 
этому предмету 4 *. А в солнечной Бразилии Билл Гейтс 
посвятил отпуск изучению “Молекулярной биологии 
гена“ Джеймса Уотсона. 

Возможно, целеустремленность, которая заставляет 
Гейтса проводить отпуск будто в читальном зале 
университета, и сделала его и возглавляемую им ком- 
панию самой мощной силой в мире программного 
обеспечения. В 1991 году объемы продаж МісгозоН 
должны были достичь 1,6 миллиарда долларов — 
больше, чем у четырех ее главных конкурентов, вме- 
сте взятых. “Он — наиболее влиятельный человек в 
компьютерной индустрии 44 , — писала газета \Ѵа11 
Зігееі .Іоигпаі. “Гейтс напоминает мне промышленных 
магнатов XIX века, силой своей воли и деловым та- 
лантом построивших нефтяные, стальные и 
банковские корпорации 44 , — отмечал обозреватель 
Стюарт Элсоп. 


.Я отнюдь не думая предлагать общему 
вниманию компилятивные биографии и 
еще менее хотел выдавать свои 
фантазии за исторические 
исследования. 


Мальчик- 
миллиардер 
из МісгозоІІ 


Но в компьютерной индустрии масса людей счи- 
тает, что Гейтс даже чересчур удачлив, и, конечно, 
его достижения не могли не дать обильной пищи для 
злых языков. “Билл Гейтс страдает манией вели- 
чия, — заявил в интервью газете Ьоз Ап^еіез Тітез 
один из производителей программного обеспечения. — 
Он хочет быть первым во всем, за что берется 44 . “Билл 
хочет оттяпать такой большой кусок программной 
индустрии, какой только может проглотить. А у него 
очень хороший аппетит 44 , — заметил другой. “Иногда 
МісгозоН наваливается всей своей тяжестью, не очень- 
то связывая себя соображениями морали. Но просто 
быть преуспевающим еще не противоречит за- 
кону 44 , — добавил третий. 

Наслушавшись подобных возмущенных возгласов 
противников, легко прийти к мнению, что Гейтс — 
это барон-грабитель века информатики. Но не все 
соглашаются с подобными оценками. 

Фелине Бальзамо старалась взглянуть на малень- 
кое существо, лежавшее около нее на широкой купе- 
ческой кровати , и говорила мужу: 

— Смотри, Пьетро, какие блистающие глаза у ма- 
лютки, какой ум написан у него на лобике!.. Навер- 
ное, он будет если не кардина.чом, то, во всяком слу- 
чае, полковником!.. 

Синьор Бальзамо , на минуту оторвавшись от 
большой расходной книги и засунув за ухо перо, повер- 
нулся к кровати и, не подходя к ней, ответил: 
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МАЛЬЧИК-МИЛЛИАРДЕР ИЗ МІСК050РТ 


— Вероятнее всего он будет честным купцом, как 
его отец и дед. Может быть , впрочем , он будет ад- 
вокатом; это теперь выгодное занятие. 

“Он на треть Эйнштейн, на треть Джон Макинрой 
и на треть генерал Паттон (командующий войсками 
союзников в Северной Африке, славившийся своей эк- 
стравагантностью )“, — говорит Хейди Ройзен, один 
из конкурентов Гейтса. Когда корреспондент РІауЬоу 
Дэвид Рензин сообщил об этой характеристике Гей- 
тсу, тот улыбнулся: “Это большой комплимент. Дол- 
жно быть, этот человек ко мне хорошо относится 4 *. 

Билл Гейтс родился 
в состоятельной 
семье. Его отец 
Уильям имеет в 
Сиэтле юридичес- 
кую практику, а 
мать Мэри возглав- 
ляет банк. Злые 
языки утверждают, 
что главой семей- 
ства является мать, 
“самая умная из 
Гейтсов“, которой 
Билл во многом 
обязан своими нынешними успехами. 

Билл закончил престижную частную школу, где в 
математике опережал даже старших. Там он познако- 
мился с Полом Алленом, сойдясь с ним на почве увле- 
чения фантастикой. Позже в местном вычислительном 
центре был создан детский кружок, в который записа- 
лись Пол и Билл, после чего они начали безбожно 
прогуливать уроки, проводя все время (даже ночью) у 
вычислительных машин. В восьмом классе Билл “со 
товарищи 44 уже зарабатывали деньги, создавая про- 
граммы, требующиеся школе. Вырученные деньги шли 
на закупку дополнительного машинного времени в том 
же центре. 

Свой выпускной класс Гейтс практически целиком 
прогулял: в это время он уже работал программистом 
в аэрокосмической корпорации ТК\Ѵ, получая 20 ты- 
сяч долларов в год. Вспоминая сегодня о том времени, 
он говорит: “В фирме ТКЛѴ я встретил человека по 
имени Нортон. Он всегда мне указывал на то, что я 
делал не очень хорошо. Так что, если я ленюсь или 
делаю что-то недостаточно тщательно, я представляю, 
что он сейчас подойдет, посмотрит и скажет: 
“Смотри, это можно сделать несколько лучше 44 . 

В 1973 году Билл поступил в Гарвардский универ- 
ситет, туда же из Вашингтонского университета пере- 
велся Пол. Там они и прочитали в журнале Рориіаг 
Еіесігопісз статью о настольном компьютере АИаіг, ос- 
нованном на разработанном фирмой Іпіеі процессоре 
8080. Объем памяти составлял 4 Кбайта, и про- 
изводитель, компания МІТ5, нуждалась в компьютер- 
ном языке, чтобы сделать машину программируемой. 

Кто-то другой, вероятно, подумал бы, но Пол и 
Билл тут же позвонили в МІТ5 и сказали, что у них 


есть очень компактная версия Бейсика. К счастью для 
них, МІТ5 назначила встречу для испытания “их 44 
Бейсика через три недели. Теперь оставалось всего 
ничего: написать эту версию. Через три недели они 
летели на встречу, в самолете дописывая свою про- 
грамму. Допусти они единственную ошибку, воз- 
можно, сегодня никто не слышал бы о фирме Мі- 
сгозоН, о АУогё, о Ѵ/тдо\ѵ5 и МЗ-ЭОЗ, но программа 
сработала, ошибок не было! 

Мальчик рос , как растут все дети небогатых куп- 
цов , хотя родители ему предоставляли больше сво- 
боды, чем это принято. И характер имел смелый, 
предприимчивый и открытый, не без некоторой 
вспыльчивости, впрочем. Был скор на руку и крайне 
самолюбив. 

В 1975 году Гейтс бросил учебу в Гарварде. Вместе 
с Алленом они переехали в штат Нью-Мексико, где 
основали МісгозоН. Первоначально Аллен настойчиво 
предлагал специализироваться на аппаратном обеспе- 
чении, но Гейтс его переубедил, считая, что двигате- 
лем компьютерной индустрии будет программное 
обеспечение. Билл не скрывает, что тогда он принял 
решение из-за очень простой вещи: “Для создания 
программы нужны только мозги, а для создания ма- 
шины еще и какие-то железки 44 . Вскоре фирма МІТ5 
прогорела, а МісгозоН получила от ІВМ предложение о 
сотрудничестве, и началась Эра Персональных Ком- 
пьютеров. 

В 1980 году ІВМ обратилась к МісгозоН с предложе- 
нием о создании базовой операционной системы для 
всех персональных компьютеров, выпускаемых ІВМ. В 
то время в МісгозоГі уже работало 38 человек, которые 
занимались разработкой и поставкой ІВМ языков про- 
граммирования, но операционной системы у них не 
было и в ближайшее время появиться не могло. Гейтс 
был вынужден, скрепя сердце, отослать ІВМ к своему 
конкуренту — фирме Эі^і^аі КезеагсН, уже тогда хо- 
рошо зарекомендовавшей себя своей операционной си- 
стемой СР/М, действующей на многих 8-разрядных 
компьютерах. Но вместе с рекомендациями обратиться 
к Оі^ііаІ КезеагсН Гейтс направил ІВМ и пространный 
труд, в котором убеждал ІВМ использовать в своем но- 
вом компьютере более мощный 16-разрядный микроп- 
роцессор 8088, разработанный к тому времени фирмой 
Іпіеі. И это сработало! В результате Оі^ііаі КезеагсН 
была вынуждена, не сумев заключить договор на по- 
ставку старой, начать разработку новой операционной 
системы, а Гейтс получил шанс воспользоваться па- 
узой. И он им воспользовался! В первый раз повезло, 
когда Пол Аллен нашел операционную систему не- 
большой фирмы ЗеаШе Сошриіег Ргобисіз, которая 
понятия не имела, что эта система позарез нужна 
ІВМ. Второй раз повезло, когда через шесть месяцев 
ІВМ выразила готовность подписать контракт на по- 
ставку новой операционной системы, и в этот момент 
президента Оі^ііаі КезеагсЬ не оказалось в Штатах — 
он был в отпуске где-то в Европе; опять же добрые 
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люди говорят, что в этот отпуск он уехал не без уча- 
стия Гейтса... Но, как бы там ни было, между этими 
двумя “везен иями“ Гейтс объявил своим близким, что 
в ближайшие шесть месяцев они его не увидят, по- 
скольку он вынужден будет работать 24 часа в сутки 
над доводкой новой операционной системы. В резуль- 
тате контракт с ІВМ был заключен! 

В 1981 году ІВМ сделала М8-Э08 сердцем новой 
машины. В соответствии с договором МісгозоН стала 
получать процент с каждого проданного персонального 
компьютера. 

Калиостро минуло тридцать три года. Он прида- 
вал большое значение этому обстоятельству , думая , 
что это „ время его выступления на историческую 
арену , и считая жизнь до этого года лишь за подго- 
товку, да и то, может быть , недостаточную к 
этому шагу. 

Сегодня М8-Э08 управляет более чем 60 милли- 
онами машин во всем мире. Получаемые МісгозоН 
проценты оцениваются в 200 миллионов долларов 
ежегодно. 

Но Гейтс не хотел зависеть только от ІВМ. Со- 
бравшись с духом, он написал очередной труд и убе- 
дил ІВМ в целесообразности продаж М8-Э08 по ли- 
цензии другим производителям персональных компью- 
теров, аргументируя это тем, что ее распространение 
поможет бороться с влиянием главного конкурента — 
Арріе Сошриіег. Но и этого ему показалось мало. Он 
убедил некоторых из ведущих производителей персо- 
налок, в частности Сотрач, делать их продукцию ПО- 
НАСТОЯЩЕМУ совместимой с продукцией ІВМ, то 
есть, чтобы любая программа, написанная для ІВМ, 
могла быть использована на этих компьютерах. В ре- 
зультате этих “убеждений 4 * М8-Э08 стали скупать в 
фантастических количествах. Изрядный кусок рынка 
был проглочен. 

Могущество Гейтса в области программного обеспе- 
чения почти беспредельно, но, по его словам, МісгозоН 
не представляет никакой угрозы для конкурентов. 
Впрочем, судите сами. После появления на рынке 
АѴігкІоіѵз 3.0, делающей компьютер вполне доступным 
для непрофессионала, Арріе подала в суд на МісгозоН, 
обвиняя ее в нарушении авторских прав. Да и ІВМ по 
этому поводу отнюдь не в восторге. До недавнего вре- 
мени МісгозоН помогала ІВМ в работе над операцион- 
ной системой 08/2, которая, как и \Ѵіпсіщѵ5 3.0, более 
наглядна для пользователя. Но после появления ЛѴіп- 
сіоѵѵз 3.0, когда за год было продано 3 миллиона эк- 
земпляров, тогда как с момента завершения разра- 
ботки в 1987 году удалось продать только 300 тысяч 
пакетов 08/2, этому сотрудничеству пришел конец. 
Сам Гейтс, отметая все обвинения, как не имеющие 
оснований, скромно говорит, что все дело в том, что 
“МісгозоН сильно изменила мир“. 

Журнал Визіпезз МопІН писал, что своим успехом 
МісгозоН обязана главным образом удаче и способно- 
сти Гейтса “нащупывать слабые места более непово- 


ротливых соперников 44 . Этот журнал приводит также 
слова неназванного “крупного деятеля компьютерной 
индустрии 44 о том, что Гейтс — не новатор. Он 
отыскивает чужие идеи и доводит их до совершенства. 
Впрочем, подобные обвинения раздавались и по адресу 
японских компаний, теснящих конкурентов по всей 
линии фронта. 

Сотрудники же фирмы Гейтса придерживаются не- 
сколько иной точки зрения. “Он просто гораздо умнее, 
чем кто-либо другой. Мы имеем дело не с обычным 
смертным, а с гением. Он способен перерабатывать 
огромный объем информации и предметно вести бе- 
седу практически на любую тему 44 , — говорит Пол 
Моритц, один из ведущих программистов компании. 

Командный дух в МісгозоН действительно развит 
сильно. Хотя сотрудники фирмы зарабатывают 
меньше, чем могли бы в других местах, и у них не 
лимитирован рабочий день, текучести кадров в компа- 
нии почти нет. Причин несколько — от возможности 
льготного приобретения акций до стремления быть в 
команде, поставившей перед собой цель достичь доми- 
нирующего положения в мире в сфере программиро- 
вания и избравшей своим девизом “Написать про- 
грамму, которая бы заставила поставить компьютер в 
каждом доме 44 . 

Со своими сотрудниками Гейтс особо не церемо- 
нится. Если кто-то приносит ему на просмотр сырую 
программу, он может ответить по-простому: “Ты что, 
дурак? 44 . Но сотрудники не обижаются, поскольку по- 
добный вопрос без серьезных оснований шеф не за- 
дает. “Он часто мочалит нас, но главное — стерпеть и 
правильно ответить. Если ты стушуешься, он переста- 
нет тебя уважать. Таковы правила игры 44 , — говорит 
программист Джефф Харберс. 

Хотя Гейтс несет 
массу обязанностей 
в качестве главного 
администратора, 
ему ничто не при- 
носит такого на- 
слаждения, как 
разбор с програм- 
мистами какой-то 
проблемы. Как за- 
метил в интервью 
журналу РІауЬоу 
Моритц, “его ува- 
жают не потому, 
что он Билл Гейтс, а потому, что он может дать каж- 
дому из ребят сто очков в профессиональных вопро- 
сах 44 . 

Сам Гейтс так формулирует качества настоящего 
программиста: “Настоящий программист никогда не 
думает: “Я заработаю кучу денег 44 или “Я продам сто 
тысяч копий 44 . Просто такие мысли ничем не помо- 
гают работе над программой. Настоящий программист 
думает: “Нужно ли переписать всю подпрограмму, 
чтобы вместо трех человек ее могли прочитать чет- 
веро? Можно ли сделать ее на 10 процентов быстрее? 
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МАЛЬЧИК-МИЛЛИАРДЕР ИЗ МІСКОЗОРТ 


Нужно ли еще раз обдумать, как вызвать эту про- 
верку?" Если вы великий программист, то вы делаете 
все программы взаимосвязанными, поэтому небольшая 
ошибка может испортить всю работу. Именно поэтому 
нужно иметь очень стройное мышление, а также же- 
лание вернуться назад и что-то изменить. Когда я ду- 
маю над структурой программы, и что-то получается, 
я чувствую себя просто здорово. Я люблю подождать и 
подготовить хорошую базу до того, как насладиться 
кодированием и видеть, что все нормально. Это вроде 
того, когда оставляешь самый вкусный кусок на та- 
релке напоследок. Иногда я завидую своим коллегам, 
которым нужно заниматься только своей программой". 

Чья карета , красная , с пестро намалеванным гер- 
бом , изображавшим в одном углу лазурного поля золо- 
тую куропатку у мчалась по Страсбургу с шести ча- 
сов утра до поздней иногда ночи? На чьем пути ни- 
щие останавливалисьу крестились и благословляли 
небо? Чей салон самый оживленный, самый много- 
людный, где бывают графы, кардиналы, базельские 
банкиры и богатые еврейки? Чье имя служит город- 
ской гордостью? 

Если Билл Гейтс 
завидует только 
своим программи- 
стам, то, видимо, 
ему завидуют очень 
многие. Ведь на се- 
годняшний день 
Гейтс — девятый 
среди самых бога- 
тых людей Аме- 
рики. К тому же 
среди них он, безу- 
словно, самый мо- 
лодой. По словам 
издателя журнала РС Ма^агіпе Билла Макрона, в 
Америке очень живуче представление, что Гейтсу где- 
то около 19 лет. Его до сих пор зовут "мальчиком- 
миллиардером". Из этих двух слов Гейтсу явно больше 
нравится первое. "Мне нравится думать о себе, как о 
молодом человеке, который жаждет бросить вызов 
устоявшемуся порядку вещей", — говорит он. Слово 
"миллиардер" его несколько коробит. "Математически 
это... гм... верно. Но такая характеристика подспудно 
подразумевает, что я люблю свою работу потому, что 
она дает экономический результат, что совершенно не 
так. Радость, подлинный кайф приносит сознание 
того, что ты смог создать компанию, и это принесло 
очень хорошие плоды". 

Однако внешне в жизни Гейтса эти плоды абсо- 
лютно не видны. Он живет по-спартански в скромном 
домике в Сиэтле. Он почти не смотрит телевизор, 
хотя и делает исключение для фильмов, выигравших 
премию Оскар, и видеокассет с записями университет- 
ских лекций по тому или иному предмету. По вече- 
рам, после 12-15-часового рабочего дня он читает. 
Мальчик-миллиардер может наизусть цитировать це- 


лые страницы из "Над пропастью во ржи" или 
"Великого Гэтсби". Если автор его увлекает, он про- 
читывает его целиком. Еда большей частью поглоща- 
ется им за рабочим столом. Чтобы поужинать дома, он 
берет чаще всего навынос пиццу или спагетти. С го- 
дами, как положено миллиардеру, он выработал в себе 
одну утонченную привычку — любовь к французскому 
шампанскому ОошРеігі^поп, в его холодильнике всегда 
хранится полдюжины бутылок этого сорта. 

Поскольку мальчик до сих пор не женат, дома, как 
и в офисе, страшнейший беспорядок: неубранная по- 
стель — привычка еще со студенческих лет, 
разбросанные кассеты с записями СНіса^о, золотой ку- 
бок за победу в национальной олимпиаде в области 
науки и техники в 1990 году и много-много каких-то 
безделушек. На стене в офисе групповой портрет той 
восьмерки, которая стояла у истоков МісгозоН в 
семидесятые годы. Выглядят они как хиппи, Гейтс, ко- 
торому не дашь больше тринадцати, сидит в левом 
нижнем углу. 

Его конкуренты ждут-не-дождутся, когда он же- 
нится. Но Гейтс, как он сам говорит, не торопится с 
этим, и, ухмыляясь, добавляет, что с кем потанцевать 
ему всегда найдется. Это подтверждают и его друзья, 
более того, они утверждают, что в этом плане его 
можно сравнить с рок-звездой. 

Но, похоже, возраст все-таки берет свое, мальчик 
становится мужчиной. А, может быть, просто груз де- 
нег стал слишком велик, надо же их куда-то девать. 
Гейтс владеет 40 процентами акций МісгозоН, и его 
личное состояние оценивается почти в 4 миллиарда 
долларов. "Да, у меня куча денег, — признает он, — 
и я совершенно свободен в том, что мне делать". Воз- 
можно, по этой причине он в последнее время до- 
вольно лихо взялся за дело. Сегодня Гейтс строит для 
себя в пригороде Сиэтла на берегу озера новый дом 
стоимостью 10 миллионов долларов. На территории 
37000 квадратных футов будут располагаться бассейн, 
трамплин, кинотеатр, пляж, подземный гараж на 20 
автомобилей, библиотека и столовая на 100 человек. 

Еще одна новая слабость — это спортивные автомо- 
били. Купленный им за 300 тысяч долларов РогзсНе 
все еще стоит в порту, так как таможня не пропускает 
его без справки о прохождении теста на безопасность 
водителя при дорожной аварии, требующейся по аме- 
риканским законам. Но дело в том, что эти модели 
слишком дорогостоящи, чтобы разбивать на стенде 
требуемые четыре машины. По этому поводу Гейтс и 
Аллен сегодня, как в добрые старые времена, на пару 
стряпают программу, имитирующую автокатастрофу, 
чтобы предъявить ее как гарантию безопасности авто- 
мобиля. 

Б. Молчанов 

По материалам: 

Э. Кепгіп, “Вііі Саіез — ЗоГі Ісоп м . РІауЪоу, ЗерІетЬег, 1991. 
5и$апп Ьатеге, “Рго^гаттега 44 . МісгозоГі Рге$$, 1986. 
М.Кузмин, “Чудесная жизнь Иосифа Бальзамо, графа Кали- 
остро. Петроград, 1919. 
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шлет пламенный ПРИВЕТ всем своим нынешним 
поклонникам ! 

говорит ДОБРО ПОЖАЛОВАТЬ своим будущим 
пользователям ! 

уже начала свое победное шествие по необъятным 
просторам одной шестой части суши. 


Вы хотите добиться успеха , применив в своем бизнесе новые информационные 
технологии? И Вы думаете , что Вам удастся осуществить это без ВИКТОРИИ? 

А Вы знаете о тех могущественных возможностях ВИКТОРИИ , обладателем 
которых можете стать ВЫ? Неужели Вы в состоянии от всего этого отказаться? 

ВИКТОРИЯ — это волшебная палочка в Ваших руках! 

Вы программист? Вы пользователь? Вы новичок? 

Новое компьютерное поколение выбирает ВИКТОРИЮ! 

Не упустите счастливый случай! 

Вам нравится А Тогіоп Соттапдег? РСТооІз? ХТгее? 

Да ведь Вы еще не работали с ВИКТОРИЕЙ! 

ВИКТОРИЯ - ЭТО Ваша СИЛА 
ВИКТОРИЯ - это Ваше МОГУЩЕСТВО 
ВИКТОРИЯ - это Ваше ПРЕИМУЩЕСТВО 

Ваш ИНТЕЛЛЕКТ и Ваша ВИКТОРИЯ сделают Вас НЕПОБЕДИМЫМ! 


И Вы все еще сомневаетесь, какую оболочку Вам выбрать? 


ВИКТОРИЯ доступна всем! Мы поддерживаем предельно низкие цены! 
ВИКТОРИЯ — это атомная бомба в Вашем компьютере 


ВИКТОРИЯ - это новая 80РТ-Б0МБА! 

ВИКТОРИЯ — это ваша рабочая лошадка! 

У Вас есть ВИКТОРИЯ! Ваши конкуренты в панике! 

Работать с ВИКТОРИЕЙ - хороший тон для 
бизнесмена! 

Вы приобрели ВИКТОРИЮ! Победа у Вас в кармане! 


винти 


© 1991 СотриІегРгеаз 
РЬопез: (095) 420-83-80 

(095) 491-01-53 
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Сделай сам 


Взять высушенное сердце жабы , залить 
отваром корней можжевельника, 
добавить пепел перьев черного петуха, 
двух скорпионов и зуб дракона и 
выпаривать после захода солнца до 
первого крика совьи 

Старинный рецепт изготовления тонера для 
лазерного принтера. 

В своей и без того нелегкой жизни советский про- 
граммист сталкивается с массой мелких проблем, ко- 
торые в своей нерешенности способны напрочь отра- 
вить радость общения с ЭВМ. Основная причина то- 
му — полная неразвитость сферы текущего техничес- 
кого обслуживания. Конечно, кое-какую помощь полу- 
чить можно, но стоит она безумных денег. Вот и при- 
ходится пользователям разбирать груды научно-техни- 
ческой литературы, брать в руки отвертки, тестеры, 
паяльники. 

Чаще всего к заминкам в работе приводит истоще- 
ние красящей ленты в принтере. Часть пользователей 
давно нашли способ легко выходить из этого затрудне- 
ния, однако, как показывает жизнь, большинство идут 
к кооператорам и покупают ленточки по 30, а то и по 
60 рублей за штуку. Когда мы несколько лет тому на- 
зад столкнулись с подобной проблемой, то решили ее 
раз и навсегда, и теперь хотим поделиться опытом с 
остальными пользователями. Заранее хочу сказать, 
технология очень проста и, вероятно, многие делают 
так, поэтому мы не претендуем на первопроходство и 
сверхоригинальность. 

Начнем с самого начала... 

Выбор ленты 

Лента, которую можно поставить в принтер, дол- 
жна обладать такими свойствами, как: 

- высокая механическая прочность волокна. Под 
воздействием иголок принтера лента не должна 
давать ворс и мелкую пыль, которые могут забить 
печатающую головку; 

- хорошая свариваемость. Нормальный, крепкий, 
аккуратный шов может дать только сварка, а не 
склейка или сшивание; 


- эластичность. Волокна ленты должны быть 
достаточно эластичны, иначе отпечатанные точки 
будут иметь неправильную форму, а это очень 
некрасиво. 

Всем этим требованиям отвечают ленты на поли- 
амидной основе. Рассмотрим полиамидные ленты, ко- 
торые может достать обычный пользователь. 

1. Ленты производства бывшей ГДР, поставлявшиеся с 
принтерами КОВОТКОЬІ. 

Ленты очень хорошие. Их отличает: 

- высокое качество печати; 

- высокая насыщенность и стойкость красящего слоя. 

Надо отметить, что краска бывает двух оттенков: чер- 
ная и фиолетовая. 

У лент этого типа есть два недостатка — слишком 
жирная печать при свежей ленте (легко смазать 
напечатанное) и сложность в доставании. 

2. Ленты производства Республики Польша, постав- 
ляемые с принтерами ЭКЮ. 

Ленты не очень высокого качества. 

Их отличает: 

- нестабильность характеристик. В одной партии 
встречаются и жесткие, и эластичные ленты, 
полувысохшие и свежие; 

- ленты относительно быстро истощаются; 

- высота ленты несколько выше стандартной (впрочем, 
и сам И 100, мягко говоря, несколько нестандартен) 
и, поэтому, она с трудом транспортируется в ЕР- 
ЗОІЧ-овском картридже. Для исправления этого не- 
достатка приходится не полностью закрывать 
крышку. Лента поставляется сваренной в кольцо и в 
специальной коробке, которая, по идее, должна 
облегчать заправку в картридж. Однако эта коробка 
не подходит ни к ЕРЗОЫ-овским, ни к 5ТАК-овским 
картриджам, так что толку от нее никакого. 

3. Импортные ленты для пишущих машинок. Ленты 
хорошие. Мы встречали индийские и чехословацкие. 

4. Лента для пишущих машинок производства СССР. 
На удивление неплохая лента, к тому же самая де- 
шевая. Обладает высокой эластичностью, хорошей 
свариваемостью. Самый большой плюс — легче всего 
достать. Честно говоря, я предпочитаю именно ее и 
считаю, что в эксплуатации лучше только ГДР- 
овская, впрочем, это мое субъективное мнение). Для 


КомпьютерПресс Г92 



МЕЖДУ ПРОЧИМ 


73 


тех, кто сразу побежал в магазин, привожу полное 
наименование этой ленты: “Лента для пишущих ма- 
шин черная красящая текстильная полиамидная. ТУ 
13-7309005 622-85“ ширина 13 мм. Сейчас она стоит 
1.80 руб., а до 2 апреля ее цена была 90 коп. 

Теперь будем считать, что лентой мы запаслись, и 
пойдем дальше... 

Сварка 

Сварка ленты — главная технологическая операция. 
Она очень проста, но от того, как вы ею овладеете, 
будут зависеть быстрота и качество замены лент. 

Прежде чем приступить к сварке лент, запаситесь 
необходимыми инструментами. Во-первых, выжига- 
тельным аппаратом. Если у вас его нет, то можно ис- 
пользовать нихромовую проволоку, закрепленную на 
ручке, и трансформатор с регулируемым напряжени- 
ем. На худой конец подойдет хорошо разогретый па- 
яльник с острым жалом. Во-вторых, вам понадобится 
ровная и гладкая деревянная дощечка. Она будет ис- 
пользоваться как подложка при сварке и не должна 
иметь лакокрасочного покрытия. Дело в том, что лак 
может легко воспламениться при касании раскаленной 
нихромовой проволокой. И, в-третьих, потребуется ме- 
таллическая линейка. Линейка должна быть ровной, 
гладкой и достаточно увесистой. Хорошо подойдет 
стальная или медная полоска толщиной 2-3 мм. 

Сам процесс сварки происходит следующим обра- 
зом: 

1. Свариваемые ленты накладываются друг на друга 
свободными концами в одну сторону и кладутся на 
деревянную дОщечку. 

2. Вдоль места будущего шва прикладывается метал- 
лическая линейка, прижимающая ленты к дощечке. 
Шов желательно делать близко к свободным концам 
(примерно 1-2 см) — тогда будет меньше отходов. 

3. Нагретым выжигателем отрезают свободные концы. 
При этом обе ленты расплавляются в месте разреза и 
слипаются. 

4. Не отнимая линейки, отделяют отрезанные концы, 
после чего сваренные ленты можно извлечь. 

Для большей надежности сварного шва можно через 
0,5-1 секунду после отрезки снять линейку и быстро 
наложить ее на еще мягкий шов и слегка прижать. 
При этом ленты склеиваются плотнее. 

При сварке надо обращать внимание на следующие 
моменты. Отрезка должна производиться выжигате- 
лем, когда нихромовая проволока нагрета до мали- 
ново-красного цвета. При более низкой температуре 
(темный цвет) может получиться некачественный 
шов, а при более высокой (соломенно-желтый цвет) 
возможно воспламенение подложки или быстрое 
перегорание нихромовой проволоки выжигателя. 
Использование деревянной дощечки и металлической 
линейки себя полностью оправдывает. Деревянная 
подложка позволяет надежно, без проскальзывания, 
прижимать ленту, а, кроме того, запах от прожига- 
емой древесины намного приятнее, чем от текстолита 


или пластика. Металлическая линейка обеспечивает 
хороший отвод тепла от сварного шва (т.е. шов бы- 
стрее твердеет), достаточное сцепление с древесиной 
(надежная фиксация ленты) и удобство в работе. 
Постарайтесь, по возможности, не сваривать разно- 
типные ленты. Как правило, химический состав мате- 
риалов основ разных лент хоть немного, да различа- 
ется, а значит различаются и их температуры плавле- 
ния. При этих условиях практически невозможно по- 
лучить прочный шов. Единственный случай, когда это 
оправдано, будет описан ниже. 

Весь процесс сварки подробно изображен на рис.1. 



Описанным выше способом получают прямой шов. 
Если вы, по каким-то причинам, хотите получить ко- 
сой шов, то свариваемые ленточки надо сложить 
крест-накрест и произвести отрезку по диагонали (см. 
рис.2). 





МЯМСи' 



Однако, как показывает опыт, косой шов не оправ- 
дывает себя, ибо краска в ленточке истощается 
раньше, чем успевает прорваться аккуратно выпол- 
ненный прямой шов. Кроме того, изготовление косого 
шва требует хорошего глазомера и аккуратности, так 
как приложить линейку и сделать отрез надо строго 
по диагонали. 
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В ряде случаев вам придется загладить шов (ряд 
принтеров рвет его). Для этого лента расстилается на 
ровном месте рубчиком шва кверху и на нее наклады- 
вается тонкая алюминиевая фольга (конечно, лучше 
использовать тонкий фторопласт, но не все его могут 
найти). Для обозначения шва пригладьте получив- 
шийся “сэндвич 44 , и тогда на фольге появится отпеча- 
ток. После этого несильно нагретым паяльником не- 
сколько раз прогладьте шов (рис.З). 


Нужно заметить, что эта операция довольно трудна, 
так как любое неправильное движение, сильное нажа- 
тие — и жало паяльника оплавит ленту в ненужном 
месте. 

В заключение раздела хочу еще раз отметить, что 
качественная сварка — залог успеха при замене лент. 
Поэтому настоятельно рекомендую потренироваться на 
старых лентах (их не жалко, да и пачкаются они 
меньше). 


кажущуюся простоту, способ довольно трудоемок и 
грязен, а частое вскрытие картриджа отнюдь не бла- 
гоприятно сказывается на сроке его службы. 

Способ заправки ленты (см. рис. 4). 

1 . Разрезается старая лента. Резать надо примерно по- 
середине. 

2. К концу, который при транспортировке втягивается 
в картридж, приваривается новая лента (это и есть 
тот случай, когда приходится сваривать разнотипные 
ленты). 

3. Путем промотки свежая лента заправляется в кар- 
тридж, а старая извлекается из него. При желании 
можно заправить несколько лент, сваривая одну с 
другой. 

4. Полученные концы новой ленты свариваются друг с 
другом. 

Налицо несколько преимуществ: 

- нет необходимости вскрывать картридж; 

- автоматически обеспечивается правильная заправка 
ленты, так как ее укладка получается путем 
штатного транспортирования; 

- так как контакт с лентой происходит только при ее 
сварке, шансов испачкаться, как поросенок, у вас 
много меньше. 

При заправке обратите внимание на следующее: во 
всех случаях нельзя допускать перекручивания лент 
(даже если лента должна быть в виде кольца Меби- 
уса). Рубчик шва должен быть на противоположной от 
печатающей головки стороне ленты. В этом случае 
иголки будут меньше разбивать шов. Правильно за- 
правленная лента показана на рис. 5. 



Заправка картриджа 

Если вы успешно овладели сваркой лент, то теперь 
самое главное — научиться заправлять картридж. На- 
иболее очевидный способ — сварить ленту, затем 
вскрыть картридж и вставить в него полученное 
кольцо. Но мы так делать не будем, ибо, несмотря на 






Так как на катушке за 1 .80 руб. содержится всего 8 
метров ленты, к тому же очень тонкой, у вас возник- 
нет естественное желание заправить в картридж 
ленты с нескольких катушек. Однако, злоупотреблять 
этим не стоит, ибо при повышенной плотности на- 
бивки ленты увеличиваются усилия, необходимые для 
ее транспортировки, что приводит к повышенному 
износу принтера, зубчатых роликов картриджа и 
ленты. Ориентировочно в картридж от узкого 
принтера ЕР80Ы можно спокойно заправить ленту с 
двух катушек, но лучше поэкспериментируйте сами с 
теми лентами, которые у вас есть. 
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В заключение необходимо заметить, что требуется, 
как минимум, 2 картриджа для принтера. В один за- 
правляется новая лента для печати документов, а в 
другой — более “забитая" лента для текущей черно- 
вой печати. При окончательном истощении черновая 
лента заменяется на новую, и картриджи меняются 
ролями. 

Что делать, если у вас 
в принтере узкая лента 

К сожалению, даже при западном уровне стандар- 
тизации в некоторых типах принтеров используются 
ленты, ширина которых отличается от ширины лент, 
выпускаемых в нашей стране. Если у вас такой прин- 
тер, то не стоит огорчаться — есть простой способ по- 
править положение. 

Сразу замечу, речь пойдет о получении лент с ши- 
риной 7-8 мм. Так как обычная лента имеет ширину 
13 или 16 мм, то сразу возникает желание разрезать 
ее вдоль на две ленты требуемой ширины. В самом 
начале мы хотели воспользоватся резаком для киноп- 
ленок, но нас остановило то, что полученная линия 
разреза — потенциальный источник пыли и ворсинок. 
Поэтому мы сделали маленький ленторезный станок. 
Конечно, он несколько сложнее инструментов для 
сварки лент, но затраты на его изготовление мгно- 
венно окупятся при эксплуатации принтера с узкой 
лентой. Обратите внимание на тщательность изгото- 
вления станка, так как от этого будет полностью зави- 
сеть качество получаемой ленты. Эскиз станка приве- 
ден на рис. 6. Я нарочно не привожу чертеж, ибо кон- 
кретная реализация зависит от имеющихся заготовок 
и деталей, а приведенные рекомендации считаю 
достаточными для самостоятельного изготовления. 

1. Подающая катушка. 2. Тормоз подающей ка- 
тушки. 3. Направляющая. 4. Лентоприжим. 5. Раз- 
делительный флажок. 6. Нихромовая проволока. 
7. Приемная катушка. 8, 9. Оси. 10. Привод. 


Подготовка к резке 

Катушка с разрезаемой лентой (1) надевается на 
ось (8). Для пропуска проволоки (6) и 
разделительного флажка (5) на ленте делается 
продольный надрез. Лента укладывается на 
направляющую (3), прижимается лентоприжимом (4) 
и закрепляется на приемной катушке (7). Резка 
ленты. 

К проволоке (6) подводится напряжение, и враще- 
нием приемной катушки осуществляется транспорти- 
рование ленты. При этом раскаленная проволока раз- 
резает ленту на две, ширина которых зависит от по- 
ложения проволоки относительно направляющих. 
Температура нагрева проволоки и скорость транспор- 
тирования подбираются опытным путем. Очевидно, 
что эти параметры непосредственно влияют на каче- 
ство резки и срок службы нихромовой проволки, кото- 
рая подвергается тепловому воздействию (значительно 
снижающему ее прочность и зависящему от подава- 
емого напряжения) и механическому, разрывному воз- 
действию со стороны разрезаемой ленты 
(определяемому скоростью резки). Некоторые замеча- 
ния по поводу назначения деталей станка. 

1. Тормоз (2) служит для получения начального на- 
тяжения ленты. 

2. Лентоприжим (4) и направляющая (3) обеспечи- 
вают правильное положение ленты при резке. 

3. Нихромовая проволока в нагретом состоянии 
обеспечивает резку ленты. При этом происходит хо- 
рошая заделка линии отреза оплавлением и га- 
рантируется отсутствие ворса и пыли при эксплуата- 
ции ленты. 

4. Флажок (5) необходим для разделения лент сразу 
за проволокой. В противном случае ленты будут сразу 
свариваться друг с другом и их придется потом разде- 
лять каким-либо способом. Если у вас есть тонкий, 
термостойкий изоляционный материал, то желательно 
флажок изготовить из него. В этом случае нихромовую 
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проволоку можно будет пустить по краю флажка, ко- 
торый будет воспринимать механические нагрузки от 
движущейся ленты. Срок службы проволоки 
значительно повысится. 

5. Механический привод. Вообще можно обойтись 
одним воротком на приемной оси, но тогда будет 
трудно обеспечить равномерное движение ленты, что 
является залогом качественной резки. Если у вас есть 
возможность, то лучше использовать электродвигатель 
с редуктором. 

В нашем случае направляющая сделана из тексто- 
лита с металлическими накладками (см. рис. 7), а 
отверстие под проволоку армировано тонкой стальной 
трубкой (отрезок иголки от шприца) (см. рис. 8). 
Такое армирование не позволяет раскаленному 
нихрому жечь текстолит. 
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Описанные выше способы работы с красящими 
лентами используются уже почти три года. При этом, 
эксплуатируя принтеры ЕР5СЖ, 5ТАЯ, Рапазопіс, 
Ашзігасі, Нуипбаі, мы ни разу не приобретали новые 
картриджи. 


Г. Родин 


ВЫ ХОТЕЛИ БЫ СТАТЬ ПАРТНЕРАМИ 
МТЕІ. ТЕСНІЖ06ІЕЗ? 


Компании ІпіеІ ТесИпоІодіез («Интел Текнолод- 
жиз») требуются дистрибуторы во всех независи- 
мых республиках, отвечающие следующим требо- 
ваниям: 


• наличие предпринимательской «жилки» 

• желание продавать новую продукцию компании 
(ІпІеІ3865ХТМ, Іп*еІ38631_ТМ, ІпіеІ4863ХТМ, 
РІазИ, ЕРЮ’з, 80186ХХ, РС РІаЙогтз, МаіИ 
Соргосеззогз, І_АМ ргобисіз, ЗайзРахііоп Ьоагсіз, 
еіс.) 

• хорошее знание рынка микроэлектроники, 
вычислительной техники и местных условий 

• возможность закупать продукцию компании за 
свободно конвертируемую валюту 

• наличие финансовых средств (минимум 50 тыс. 
долларов США) для первоначальной закупки 
продукции компании, организации работы и 
соответствующей инфраструктуры 

• наличие квалифицированных кадров на 
должность торгового представителя и агентов 
по продаже и обслуживанию продаваемого 
оборудования. 


Компания Іпіеі Тесбпоіодіез является филиалом 
американской корпорации ІпіеІ в Советском Союзе. 
Корпорация Іпіеі — одна из ведущих фирм в обла- 
сти микроэлектроники и вычислительной техники 
с годовым оборотом более 4 млрд, долларов. 
Марка Іпіеі означает последние достижения 
научно-технического прогресса, высокое качество 
и надежность. 

Если Вы отвечаете указанным требованиям и хо- 
тели бы подробнее ознакомиться с нашими пла- 
нами по созданию дистрибуторской сети, пожалуй- 
ста, обращайтесь в московский офис компании Іпіеі 
ТесИпоІодіез: 



тел.: 388-61 -00 , 
факс: 388-59-81 , 230-29-39 
телекс: 612093 ЗМАИ 511 
адрес : 1 1 3 1 05 Москва 
Варшавское шоссе, 37а 
Международный почтамт 
а/я 145 
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Банковское обслуживание через 
^путники началось в Индии 2 декабря, 
ко'гда 26 банков этой страны стали або- 
нентами сети Зосіеіу Іог \Ѵог1<і-\ѵісІе 
ІпіегЬдпк Ріпапсіаі Теіесотшипісаііоп 
(8ШРТ.І. Среди участников Зіаіе Вапк 
оГ Іпсііа, Вапк оГ Іпсііа, Вапк оі Вагосіа 
и Сапага Вапк, сейчас их терминалы 
подсоединены к центру 3\ѴІРТ в Бом- 
бее, откуда сообщения передаются в 
Лондон или Сингапур и далее в другие 
банки. Идея родилась в Индийской 
Банковской Ассоциации еще в 1982 
году, но разрешение правительства 
было получено только в июне 1991 
года. В деятельности 8ЧѴІРТ наме- 
чается новый этап — как раз тогда, 
когда начались испытания 8>Ѵ7РТ II. 

ТНе Теіериііпв Ноіііпе , 
ОесепхЬег 10 1991 

АТ&Т ВЕІХ ЕАВЗ анонсировали 
м Ьиску№1, и схему работы сети со ско- 
ростью 2.5 Гбит/с, которая может 
функционировать с волоконно-опти- 
ческими или микроволновыми пере- 
датчиками. 

ТНе Теіериііщ Ноіііпе, 
йесетЪег 10 1991 

Каждая индустрия проходит через 
этапы, которые легко опознать. На 
первом этапе пионеры испытывают 
трудности первопоселенцев, доказывая, 
что рынок все-таки существует. На 
втором этапе появляется толпа и 


начинается настоящая конкуренция. 
Третья стадия — перетряска. Она 
отмечается переходом в зрелое состо- 
яние и снижением конкуренции. 
Четвертый этап — зрелая инду- 
стрия — наиболее доходен. 

Компьютеризация “в полевых усло- 
виях 14 (вне офисов) сейчас входит во 
вторую стадию. Образуется толпа кон- 
курентов. Что касается беспроводных 
сетей, то за последние несколько не- 
дель ВеІІЗоиІІі приобрела половину 
сети РАМ МоЬіІе, СІоЬаІ Зіаг объявила 
о создании сети низкоорбитальных 
спутников, которая будет конку- 
рировать с проектом Ігісііит компании 
Моіогоіа, а МсСаѵѵ Сеііиіаг и Огасіе 
Зу8(ет$ подыскивают частоту для 
службы радиопередачи данных. 

В каждой области компьютеризации 
вне офисов есть несколько конкурен- 
тов. Если вы предпочитаете радиоча- 
стоты, то к вашим услугам КАМ и 
АКПІЗ. Если вам нравятся более высо- 
кие частоты, то — Міеі и МСа\ѵ. 
Производители модемов стремглав бро- 
сились эксплуатировать сотовые ча- 
стоты, и планируются две спутниковые 
сети. Если взглянуть на терминалы, то 
программное обеспечение предлагают 
Со, Місго8оП и Мотепіа, среди произ- 
водителей нового аппаратного обеспе- 
чения такие гиганты, как ІВМ и АТ&Т. 
Без сомнения, основные японские про- 
изводители не заставят себя долго 
ждать. 


Все это означает, что вам нужно 
тщательно рассмотреть ваши собствен- 
ные действия. Определите, какая часть 
ваших сотрудников работает вне офи- 
сов. Подумайте о том, как компьютер- 
ные ресурсы могут увеличить их про- 
изводительность. Определите воз- 
можные решения. Выясните намерения 
конкурентов. И приготовьтесь к тому, 
чтобы купить оборудование в 1 992 
году. 

Если вы этого не сделаете, это сде- 
лает ваш конкурент. В результате он 
предложит лучшее обслуживание или 
более низкие цены. А учитывая про- 
должающийся экономический спад, 
это и есть разница между скромными 
доходами и банкротством. 

ТНе Теіериііпв Ноіііпе, 
ИесетЬег 5, 1991 

Науез Місгосотриіег Ргосіисіз и ОРТ 
открыли в Ноттингеме лабораторию 
разработки прикладных программ для 
ІЗЭК (интегрированных цифровых се- 
тей). Обе компании производят изде- 
лия для ШЖ: Науе$ выпускает адап- 
теры для компьютеров, ОРТ — теле- 
фоны ШЖ. Две компании хотят, 
чтобы разработчики программного 
обеспечения использовали набор АТ- 
команд фирмы Науез и ВЮЗ I5^N для 
создания реальных прикладных про- 
грамм для предприятий в Европе и 
США. ВгіІізН Теіесош сообщает, что 
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число абонентов ее службы I5^N 2 со- 
ставляет десятки тысяч. I5^N 2 обес- 
печивает по двухпроводному телефон- 
ному соединению два канала данных 
со скоростью передачи 64,000 бит в 
секунду плюс управляющий канал. 
Обещается увеличение сети. 

Тке Теіериііпв Ноіііпе, 
ОесетЬег 5, 1991 

Японское агентство ІпГогтаііоп Рго- 
се$$іп& А^епсу сообщило, что за по- 
следние два месяца зарегистрировано 
рекордное число компьютерных виру- 
сов. Ущерб, нанесенный ими, чрезвы- 
чайно невелик. Из 1 1 вирусов, о кото- 
рых сообщалось в сентябре, восемь 
действовали на компьютере КЕС 
РС-9801, являющимся стандартным в 
Японии. Большинство сообщений 
пришли из Токио. Новейший вирус 
называется “Ѵассіпа“ — это безвредное 
заболевание, инфицирующее машины 
с МЗ-ЭОЗ. 

В США, по сообщению Оа(аяие$1, 
63% владельцев персоналок столкну- 
лись с вирусами, а 9% потерпели 
ущерб на двадцати пяти или более 
компьютерах. Самые серьезные опас- 
ности подстерегают большие компании. 
В США сейчас известно о примерно 
1000 различных вирусных программах. 

Тке Теіериііпв Ноіііпе , 
ОесетЬег 5, 1991 

СНАКЬЕЗ 5СН\ѴАВ отменила взи- 
мание ежемесячной платы с клиентов, 
читающих котировки акций в системе 
СЕпіе в реальном времени. Поминут- 
ная оплата остается в силе. 


СО СОКРОЯАТКЖ откроет в Япо- 
нии предприятие для разработки и 
сбыта японской версии своего про- 
граммного обеспечения РепРоіп! для 
компьютеров с рукописным вводом в 
начале 1993 года. 

НАѴЕ5, крупнейший производитель 
модемов для персональных компьюте- 
ров, сообщила что в 1991 году объем ее 
продаж в Европе вырос на 70%, в 
Азии — на 100%, в то время как 
общие доходы возросли на 15%. 

МІСКОЗОРТ анонсировала шлюзы 
между своей системой Місгозой Маіі и 
ІВМ РгоГз, факсом, Х.400, ЗМТР/Лпіх, 
ІЧоѵеІІ МН5 и МСІ Маіі. 

В АВСТРАЛИЙСКОЙ ПРО- 
ВИНЦИИ Новый Южный Уэльс на- 
чала работу ТЪе Етріоутепі №і\ѵогк 
(ТЕЮ, он-лайновая служба, соединя- 
ющая нанимателей с потенциальными 
работниками. 

КЕ1ГГЕК8 представила систему Эе- 
сі8іоп 2000, которая дает возможность 
валютным биржевикам анализировать 
он-лайновую информацию агентства 
по облигациям перед сделками. 

5НАРЕ\ѴАКЕ РиВЫЗНІМС будет 
продавать пакет связи Осіуззеу РС в 
Великобритании. Компания прошлым 
летом отказалась от Ргосотт. 

ТЕЬЕВІТ усовершенствует свой но- 
вый модем Ѵ.32Ъі$, Т3000, с помощью 
своего собственного протокола. 

Тке Теіериііпз Ноіііпе, 
ОесетЬег 5, 1991 

Датская телефонная компания объя- 
вила об установлении волоконно-опти- 
ческой и спутниковой связи с Россией. 
Используется спутниковая система 
американской компании Ни^Нез, да- 


ющая возможность прямой телефонной 
связи между Восточной и Западной 
Европой. Сейчас, звоня по телефону, 
часто слышишь гудки “занято 4 *, сооб- 
щения типа “ждите ответа “ или стал- 
киваешься с отсутствием сигнала на 
линии. С введением новой линии жить 
станет легче. 

Подсоединение будет осуществлено 
через систему Еиіеізаі. Оптико-воло- 
конная линия от Копенгагена до Кин- 
гисеппа будет создана датскими СЫ 
Зіоге ^г(1 А/3 и Теіе Оаптагк А/3. 
Уже заабонировано 15,360 каналов. 
Между Москвой и Кингисеппом при- 
дется устанавливать радиосвязь, так 
как Запад отказывается поставлять 
российскому правительству оптико-во- 
локонный кабель. Система начнет ра- 
ботать весной 1993 года. 

Тке Теіериііпв Ноіііпе, 
ОесетЬег 3, 1991 

Зіегта №Ьѵогк присоединилась к. 
РгосЯ^у и Сотризегѵе и стала третьей 
американской он-лайновой системой, 
предлагающей в розничной торговле 
наборы для начала работы в своей си- 
стеме. Зіегта является игровой систе- 
мой. ЗіаП-Цр Кіі стой? 29.95 долл. 
Предлагается набор: шахматы, элек- 
тронный корректор, бридж, мини- 
гольф, он-лайновые беседы. Приложе- 
ния включают электронную почту, 
конференции и путеводители по играм 
Зіегта. 

Тке ТеІериііп% Ноіііпе, 
ОесетЬег 3, 1991 

Егіс$$оп СЕ подписала соглашение с 
Ашіегіог ТесНпоІояу и Ке$еагсН Іп Мо- 


Специально для пользователей С1ЛРРЕК 

Оболочка Сііррег: Привычный интерфейс Т игЬо-систем плюс весь 
необходимый инструментарий программиста. 

АКЦИОНЕРНОЕ ОБЩЕСТВО 

Конструктор программиста: Возможность конструирования 103706 Москва, пл. Куйбышева 1, тел 298-88-88 
прикладных систем из функциональных и технологических моду- 
лей поставляемой нами библиотеки исходных текстов. 


СОВЛй 


Генераторы отчетов: Генератор “РогтаГ для быстрой обработ- 
ки ёЫ-файлов супербольших размеров. Генератор “СепШ” для 
начинающего пользователя. “РогтаГ’ и“ОепІІ$” — это выходные 
формы любой сложности без проблем и ошибок. 


Разработчики , Вам необходимо 
опередить своих конкурентов! 
Наши программные средства и 
методы помогут Вам в этом. 
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Поп (КІМ) о разработке беспроводного 
шлюза для электронной почты. Шлюз 
Касііотаіі фирмы Аліегіог сможет со- 
единит сеть ВАМ МоЬПе Оаіа МоЬііех с 
такими системами, как АТТ Маіі, поч- 
товыми системами ЛВС типа ЬоШа 
сс:Маі1, а также с сетями ТСР/ІР Іп- 
іегаеі и ШСР/ІЛ5ЕКЕТ. КІМ создаст 
программное обеспечение, дающее 
портативным компьютерам доступ к 
шлюзу через радиомодемы Егісззоп 
СЕ. Первым устройством, имеющим 
такие возможности, станет раітіор- 
компьютер НР 95ЬХ. 

ТНе Теіериііпв Ноіііпе, 
ЭесетЬег 3, 1991 

Азкгі анонсировала сделанный в Со- 
ветском Союзе пакет шифрации для 
ІВМ РС, отвечающий Баіа Епсурііоп 
ЗіапсІагсі (Стандарт шифрации дан- 
ных). Сгуріоз является первым пакетом 
такого рода в России. Это стандарт, 
использующийся Агентством Наци- 
ональной Безопасности США, которое 
сейчас пытается ввести другой алго- 
ритм. Американские компании возра- 
жают против этого, так как они вло- 
жили деньги в БЕЗ, а также потому, 
что правительство получит возможно- 
сти по шифрации, которых не будет у 
частных фирм. Кирилл Чащин пишет 
для №\ѵзЪу1е$, что главное для совет- 
ских пользователей то, что их компью- 
теры могут теперь работать с БЕЗ, 
даже если создание новых ключей на 


ІВМ РС АТ занимает час. Стоить 
Сгуріоз будет 5,000 рублей. 

ТНе Теіериііпв Ноіііпе , 
ИоѵепхЬег 26 , 1991 

АРРЬЕ выходит на рынок мо- 
бильных устройств приема-передачи 
данных с помощью интерфейса сото- 
вых модемов Ах$у$ фирмы Зресігит 
Сеііиіаг. 

ВЕІТІЗН ТЕЬЕСОМ приобрела 
компанию РТТ АІрНапишегіс, которая 
производит системы программного 
обеспечения для заключения сделок, 
используемые брокерами на биржах. 

ШТ выпустила изделие, назы- 
ваемое ею самым надежным фак- 
симильным аппаратом в мире, который 
снабжен мощными возможностями по 
шифрации и дешифрации. Модели се- 
рии Т используют криптографическую 
систему РЕАЬ-8 ШТ. 

ТНе Теіериііпв Ноіііпе , 
ИоѵетЬег 26 , 1991 

Ограничения на торговлю с Че- 
хословакией, Венгрией и Польшей, 
основанные на соображениях безопас- 
ности, могут быть скоро сняты, так что 
эти страны смогут купить волоконно- 
оптические телефонные системы. Рос- 
сия по-прежнему не может этого сде- 
лать, в то время, как Китай и Иран 
продолжают развивать свои надежные 
волоконные сети. В любом случае из 
списка высокотехнологичных товаров, 


запрещенных к экспорту, вычеркива- 
ется все больше и больше изделий, 
включая компьютеры типа ІВМ РС. В 
СОСОМ входят все члены военного 
союза НАТО, кроме Исландии, плюс 
Австралия и Япония. 

ТНе Теіериііпв Ноіііпе, 
ИоѵетЬег 21, 1991 

АРРЬЕ направила запрос пра- 
вительству о введении 63% тарифа на 
ввоз активных жидкокристаллических 
матричных плоских дисплеев, типа 
того, который используется в порта- 
тивном МасіпіозН'е. Многие американ- 
ские производители компьютеров-блок- 
нотов уже перенесли производство в 
другие страны, так как они в таких 
условиях не могут создать конкурен- 
тоспособные продукты дешевле 20,000 
долларов, против 2,000 долларов за 
японские машины. 

НЕХѴЬЕТТ-РАСКАКЭ и синга- 
пурские фирмы представили факс-ап- 
парат серии Сгоир IV, использующий 
линии ІЗЭК и работающий даже когда 
пользователи по той же самой линии 
ведут обычный разговор. 

ХЕС, Ма&и$Нііа Еіесігіс и Мі&иЪізНі 
Еіесігіс готовят соглашение по совмест- 
ной разработке интегральных схем для 
телевидения высокой четкости. К со- 
юзу могут также присоединиться 
АТ&Т Місгоеіесігопісз и ЬЗІ Ьо^іс. 

ТНе Теіериііпя Ноіііпе, 
ИоѵетЬег 21, 1991 


БАЗЫ ДАННЫХ И ЭКСПЕРТНЫЕ СИСТЕМЫ" 


От кого 
Адрес 


На (шесть, три) выпусков. Количество экз. 

Прошу оформить подписку на 1992 год 

Подписная плата в сумме 

платежным поручением N 0 . от 

(Копия платежного поручения прилагается) 


Руководитель 


(подпись, фамилия, инициалы) 

Примечание. Заказ высылать по адресу: 123459 Москва а/я 20 


руб. перечислена 
199 г. 
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Г 

У| Принимает заказы на журнал “ КомпьютерПресс “ и 

производит отправку наложенным платежом. 


Заказ высылается по адресу: 191186, Санкт-Петербург, Невский проспект, 28 

Магазин № 1 “Дом Книги“ 


От кого 


Адрес 


(почтовый индекс указывать обязательно) 


V 


Номера выпусков Количество экземпляров 


>ч 


✓ч ^(1^9 Советско-американское предприятие “ Соваминко“ 
| 2 Рекламно-издательское агентство “ КомпьютерПресс “ 

Принимает заказы на журнал “ КомпьютерПресс “ 
і У и производит 


отправку наложенным плетжом 


Заказ высылается по адресу: 630076, Новосибирск, Красный проспект, 60 

Магазин № 7 ‘Техническая книга 44 

Телефон для справок 20-05-09 

От кого 


Адрес . 


Номера выпусков 


Количество экземпляров 


АКЦИОНЕРНОЕ ОБЩЕСТВО 



...от персональных компьютеров — 
до специализированной мебели... 
...от программных продуктов — 
до обучения пользователей... 

ВСЁ 

для создания образцовых бирж труда 
(центров занятости), 
отделов социального обеспечения 

и офисов! 


103706 Москва, пл. Куйбышева, 1. Телефон: 298-88-20. Факс: 298-83-61 


СЕТЬ ПЕРЕДАЧИ СООБЩЕНИЙ 


Ре/сот — 

ЧАСТЬ ВСЕМИРНОЙ СИСТЕМЫ 
ТЕЛЕКОММУНИКАЦИЙ 


Сеть КЕЬСОМ 1 
доставит Ваше 
сообщение зарубежному 
и советскому адресату 
менее чем за 3 часа 

Единственный недостаток 
сети КЕЬСОМ — 
однажды 

воспользовавшись ею, 

Вы будете делать это 
всю жизнь 

Сеть КЕЬСОМ — это 
не окно, это 
открытая дверь 

1 

в мир компьютерных 
коммуникаций, 

У ВАС ЕСТЬ ВЫХОД! 


Телефоны: 

( 095 ) 231 - 63-95 

( 095 ) 231 - 21-29 

( 095 ) 233 - 06-70 

( 095 ) 196 - 72-50 

Факсы : 
( 095 ) 233 - 50-16 
( 095 ) 196 - 49-84 


